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PREFACE 



This manual describes programming with Intel's assembly language. It will not teach you how to program a computer. 

Although this manual is designed primarily for reference, it also contains some instructional material to help the beginning 
programmer- The manual is organized as follows: 

Chapter 1. ASSEMBLY LANGUAGE AND PROCESSORS 

Description of the assembler 

Overview of 8080 hardware and instruction set 

Description of 8080/8085 differences 

Chapter 2. ASSEMBLY LANGUAGE CONCEPTS 

General assembly language coding rules 

Chapter 3. INSTRUCTION SET 

Descriptions of each instruction (these are listed alphabetically 
for quick reference) 

Chapter 4. ASSEMBLER DIRECTIVES 

Data definition 
Conditional assembly 
Relocation 

Chapter 5. MACROS 

Macro directives 
Macro examples 

Chapter 6. PROGRAMMING TECHNIQUES 

Programming examples 

Chapter 7, INTERRUPTS 

Description of the interrupt system- 
Chapters 3 and 4 will fill most of the experienced programmer's reference requirements. Use the table of contents or the 
index to locate information quickly, 

The beginning programmer should read Chapters 1 and 2 and then skip to the examples in Chapter 6. As these examples 
raise questions, refer to the appropriate information in Chapter 3 or 4. Before writing a program, you will need to read 
Chapter 4. The 'Programming Tips' in Chapter 4 are intended especially for the beginning programmer. 



RELATED PUBLICATIONS 

To use your Intetlec development system effectively, you should be familiar with the following Intel 
publications: 



ISIS-II 8080/8085 MACRO ASSEMBLER OPERATOR'S MANUAL, 9800292 

When you activate the assembler, you have the option of specifying a number of controls. The operator's 
manual descriaes the activation sequence for the assembler. The manual also describes the debugging tools 
and the error messages supplied by the assembler. 



ISIS-II SYSTEM USER'S GUIDE, 9800306 

User program, are commonly stored on diskette files. The ISIS-II Users Guide describes the use of the text 
editor for entering and maintaining programs. The manual also describes the procedures for linking and 
locating relocatable program modules. 



Hardware References 

For additional information about processors and their related components, refer to the appropriate User's 
Manual: 

8080 MICROCOMPUTER SYSTEMS USER'S MANUAL, 9800153 

8085 MICROCOMPUTER SYSTEMS USER'S MANUAL, 9800366 
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1. ASSEMBLY LANGUAGE AND PROCESSORS 



INTRODUCTION 



Almost every line of source coding in an assembly language source program translates directly into a machine 
instruction for a particular processor- Therefore, the assembly language programmer must be familiar with both 
the assembly language and the processor for which he is programming. * 

The first part of this chapter describes the assembler. The second part describes the features of the 8080 micro- 
processor from a programmers point of view. Programming differences between the 8080 and the 8085 micro- 
processors are relatively minor. These differences are described in a short section at the end of this chapter. 



WHAT iS AN ASSEMBLER? 

An assembler is a software too! — a program — designed to simplify the task of writing computer programs. If 
you have ever written a computer program directly in a machine-recognizable form such as binary or hexadecimal 
code, you will appreciate the advantages of programming in a symbolic assembly language. 

Assembly language operation codes (opcodes) are easily remembered (MOV for move instructions, jMP for jump). 
You can also symbolically express addresses and values referenced in the operand field of instructions. Since you 
assign these names, you can make them as meaningful as the mnemonics for the instructions. For example, if your 
program nrust manipulate a date as data, you can assign it the symbolic name DATE. If your program contains a 
set of instructions used as a timing loop (a set of instructions executed repeatedly until a specific amount of time 
has passed), you can name the instruction group TIMER. 



What the Assembler Does 

To use the assembler, you first need a source program. The source program consists of programmer-written 
assembly language instructions. These instructions are written using mnemonic opcodes and labels as described 
previously. 

Assembly language source programs must be in a machine-readable form when passed to the assembler. The 
Intellec development system includes a text editor that will help you maintain source programs as paper tape 
files or diskette files. You can then pass the resulting source program file to the assembler, (The text editor is 
described in the ISIS-II System User's Guide.) 

The assembler program performs the clerical task of translating symbolic code into object code which can be 
executed by the 8080 and 8085 microprocessors. Assembler output consists of three possible files: the object 
file containing your program translated into object code; the list file printout of your source code, the assembler- 
generated object code, and the symbol table; and the symbol-cross-reference file, a listing of the symbol-cross- 
reference records. 
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Figure 1-1. Assembler Outputs 



Object Code 



For most microcomputer applications, you probably will eventually load the object program into some form of 
read only merr.ory. However, do not forget that the Intel lee development system is an 8080 microcomputer 
system with random access memory. In most cases you can load and execute your object program on the 
development system for testing and debugging. This allows you to test your program before your prototype 
application sys:em is fully developed. 

A special feature of this assembler is that it allows you to request object code in a relocatable format. This frees 
the programmer from worrying about the eventual mix of read only and random access memory in the application 
system; individual portions of the program can be relocated as needed when the application design is final. Also, 
a large program can be broken into a number of separately assembled modules. Such modules are both easier to 
code and to te,t. See Chapter 4 of this manual for a more thorough description of the advantages of the relocation 
feature. 



Program Listing 

The program listing provides a permanent record of both the source program and the object code. The assembler 
also provides diagnostic messages for common programming errors in the program listing. For example, if you 
specify a 16-bi value for an instruction that can use only an 8-bit value, the assembler tells you that the value 
exceeds the pcmissible range. 
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Symbol-Cross-Reference Listing 

The symbol-cross-reference listing is another of the diagnostic tools provided by the assembler. Assume, for 
example, that your program manipulates a data field named DATE, and that testing reveals a program logic 
error in the handling of this data. The symbol-cross-reference listing simplifies debugging this error because it 
points you to each instruction that references the symbol DATE. 



Do You Need the Assembler? 

The assembler is but one of several tools available for developing microprocessor programs. Typically, choosing 
the most suitable tool is based on cost restraints versus the required level of performance. You or your company 
must determine cost restraints; the required level of performance depends on a number of variables: 

© The number of programs to be written: The greater the number of programs to be written, the more 
you need development support. Also, it must be pointed out that there can be penalties for not 
writing programs. When your application has access to the power of a microprocessor, you may be 
able to provide customers with custom features through program changes. Also, you may be able to 
add features through programming. 

© The time allowed for programming: As the time allowed for programming decreases, the need for 
programming support increases. 

© The level of support for existing programs: Sometimes programming errors are not discovered until 
the program has been in use for quite a while. Your need for programming support increases if you 
agree to correct such errors for your customers. The number of supported programs in use can 
multiply this requirement. Also, program support is frequently subject to stringent time constraints. 

If none of the factors described above apply to your situation, you may be able to get along without the 
assembler. Intel's PROMPT-80, for example, allows you to enter programs directly into programmable read only 
memory, You enter the program manually as a string of hexadecimal digits. Such manual programming is relatively 
slow and more prone to human error than computer-assisted programming. However, manual systems are one of 
the least expensive tools available for microprocessor programming. Manual systems may be suitable for limited 
applications, hobbyists, and those who want to explore possible applications for microprocessors. 

If most of the factors listed previously apply to you, you should explore the advantages of PL/M. PL/M Is 
Intel's high-level language for program development. A high-level language is directed more to problem solving 
than to a particular microprocessor. This allows you to write programs much more quickly than a hardware- 
oriented language such as assembly language. As an example, assume that a program must move five characters 
from one location in memory to another. The following example illustrates the coding differences between 
assembly language and PL/M. Since instructions have not yet been described, the assembly language instructions 
are represented by a flowchart. 
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ASSEMBLY LANGUAGE CODING 



LOAD REGISTER WITH NUMBER 
OF CHARACTERS TO BE MOVED 



LOAD REGISTER PAIR B WITH 
ADDRESS OF SOURCE (FLD1) 



LOAD REGISTER PAIR D WITH 
ADDRESS OF DESTINATION 
(FLD2) 



LOAD ACCUMULATOR WITH 1 
BYTE FROM SOURCE FIELD 



MOVE CHARACTER FROM 
ACCUMULATOR TO DESTINA- 
TION FIELD 



INCREMENT SOURCE ADDRESS 



INCREMENT DESTINATION 
ADDRESS 



DECREMENT CHARACTER COUNT 




\ 



> 



/ 



PL/M CODING 



CALL MOVE(5,FLD2,FLD1) 



C 



CONTINUE 



) 



Figure 1-2. Comparison of Assembly Language with PL/M 
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OVERVIEW OF 8080/8085 HARDWARE 



To the programmer, the computer comprises the foiiowing parts: 



Memory 

The program counter 

Work registers 

Condition flags 

The stack and stack pointer 

Input/output ports 

The instruction set 



Of the components listed above, memory is not part of the processor, but is of interest to the programmer. 



Memory 



Since the program required to drive a microprocessor resides in memory, all microprocessor applications require 
some memory, There are two general types of memory: read only memory (ROM) and random access memory 
(RAM). 



ROM 



As the name implies, the processor can only read instructions ^nd data from ROM; it cannot alter the contents 
of ROM. By contrast, the processor can both read from and write to RAM. Instructions and unchanging data 
are permanently fixed into ROM and remain intact whether or not power is applied to the system. For this 
reason, ROM is typically used for program storage in single-purpose microprocessor applications. With ROM you 
can be certain that the program is ready for execution when power is applied to the system. With RAM a program 
must be loaded into memory each time power is applied to the processor. Notice, however, that storing programs 
in RAM allows a muiti-purpose system since different programs can be loaded to serve different needs. 

Two special types of ROM - PROM (Programmable Read Only Memory) and EPROM (Eraseable Programmable 
Read Only Memory) — are frequently used during program development. These memories are useful during 
program development since they can be altered by a special PROM programmer, in high-volume commercial 
applications, these special memories are usually replaced by less expensive ROM's. 



RAM 



Even if your program resides entirely in ROM, your application is likely to require some random access memory. 
Any time your program attempts to write any data to memory, that memory must be RAM. Also, if your pro- 
gram uses the stack, you need RAM. If your program modifies any of its own instructions (this procedure is 
discouraged), those instructions must reside in RAM. 

The mix of ROM and RAM in an application is important to both the system designer and the programmer. 
Normally, the programmer must know the physical addresses of the RAM in the system so that data variables 
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can be assignee within those addresses. However, the relocation feature of this assembler allows you to code a 
program without concern for the ultimate placement of data and instructions; these program elements can be 
repositioned af :er the program has been tested and after the system's memory layout is final. The relocation 
feature is fully explained in Chapter 4 of this manual. 



Program Counter 

With the progrim counter, we reach the first of the 8080's internal registers illustrated in Figure 1-3. 

NOTE 

Except for the differences listed at the end of this chapter, 
the information in this chapter applies equally to the 8080 
and the 8085. 

The program counter keeps track of the next instruction byte to be fetched from memory (which may be either 
ROM or RAM}. Each time it fetches an instruction byte from memory, the processor increments the program 
counter by on':. Therefore, the program counter always indicates the next byte to be fetched. This process 
continues as long as program instructions are executed sequentially, To alter the flow of program execution as 
with a jump instruction or a call to a subroutine, the processor overwrites the current contents of the program 
counter with tie address of the new instruction. The next instruction fetch occurs from the new address. 
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Figure 1-3. 8080/8085 Internal Registers 
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Work Registers 

The 8080 provides an 8-bit accumulator and six other general purpose work registers, as shown in Figure 1-3. 

Programs reference these registers by the letters A (for the accumulator}, B, C, D, E, H, and L. Thus, the 
instruction ADD B may be interpreted as 'add the contents of the B register to the contents of the accumu- 
lator. 

Some instructions reference a pair of registers as shown in the following: 

Symbolic Reference Registers Referenced 

B 8 and C 

D D and E 

H H and L 

M H and L (as a memory reference) 

PSW A and condition flags (explained 

later in this section) 



The symbolic reference for a single register is often the same as for a register pair. The instruction to be executed 
determines how the processor interprets the reference. For example, ADD B is an 8-bit operation. By contrast 
PUSH B (which pushes the contents of the B and C registers onto the stack) is a 16-bit operation. 

Notice that the letters H and M both refer to the H and L register pair. The choice of which to use depends on 
the instruction. Use H when an instruction acts upon the H and L register pair as in INX H (increment the 
contents of H and L by one). Use M when an instruction addresses memory via the H and L registers as in ADD 
M (add the contents of the memory location specified by the H and L registers to the contents of the accumu- 
lator). 

The general purpose registers B, C, D, E, H, and L can provide a wide variety of functions such as storing 8-bit 
data values, storing intermediate results in arithmetic operations, and storing 16-bit address pointers. Because of 
the 8080's extensive instruction set, it is usually possible to achieve a common result with any of several 
different instructions, A simple add to the accumulator, for example, can be accomplished by more than half a 
dozen different instructions. When possible, it is generally desirable to select a register-to-register instruction 
such as ADD B. These instructions typically require only one byte of program storage. Also, using data already 
present in a register eliminates a memory access and thus reduces the time required for the operation. 

The accumulator also acts as a general-purpose register, but it has some special capabilities not shared with the 
other registers. For example, the input/output instructions IN and OUT transfer data only between the accumu- 
lator and external I/O devices. Also, many operations involving the accumulator affect the condition flags as ex- 
plained in the next section. 

Example: 

The following figures illustrate the execution of a move instruction. The MOV M.C moves a copy of the contents 
of register C to the memory location specified by the H and L registers. Notice that this location must be in 
RAM since data is to be written to memory, 
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Figure 1-4, Instruction Fetch 



The processor initiates the instruction fetch by latching the contents of the program counter on the address bus, 
and then increments the program counter by one to indicate the address of the next instruction byte. When the 
memory responds, the instruction is decoded into the series of actions shown in Figure 1-5. 



NOTE 

The foilowing description of the execution of the 
MOV M,C instruction is conceptually correct, but 
does not account for normal bus control. For details 
concerning memory interface, refer to the User's 
Manual for your processor. 
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Figure 1-5. Execution of MOV M,C Instruction 



To execute the MOV M,C instruction, the processor latches the contents of the C register on the data bus and 
the contents of the H and L registers on the address bus. When the memory accepts the data, the processor 
terminates execution of this instruction and initiates the next instruction fetch. 



Internal Work Registers 

Certain operations are destructive. For example, a compare is actually a subtract operation; a zero result indicates 
that the opreands are equal. Since it is unacceptable to destroy either of the operands, the processor includes 
several work registers reserved for its own use. The programmer cannot access these registers. These registers are 
used for internal data transfers and for preserving operands in destructive operations. 



Condition Flags 

The 8080 provides five flip flops used as condition flags. Certain arithmetic and logical instructions alter one or 
more of these flags to indicate the result of an operation. Your program can test the setting of four of these 
flags (carry, sign, zero, and parity) using one of the conditional jump, call, or return instructions. This allows you 
to alter the flow of program execution based on the outcome of a previous operation. The fifth flag, auxiliary 
carry, is reserved for the use of the DAA instruction, as will be explained later in this section. 

It is important for the programmer to know which flags are set by a particular instruction. Assume, for example, 
that your program is to test the parity of an input byte and then execute one instruction sequence if parity is 
even, a different instruction set if parity is odd. Coding a JPE (jump if parity is even) or JPO (jump if parity is 
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odd) instruction Immediately following the IN (input) instruction produces false results since the IN instruction 
does not affect the condition flags. The jump executed by your program reflects the outcome of some previous 
operation unrelated to the IN instruction. For the operation to work correctly, you must include some instruc- 
tion that alters the parity flag after the IN instruction, but before the jump instruction. For example, you can 
add zero to tie accumulator. This sets the parity flag without altering the data in the accumulator. 

In other cases you will want to set a flag with one instruction, but then have a number of intervening instruc- 
tions before you use it. In these cases, you must be certain that the intervening instructions do not affect the 
desired flag. 

The flags set by each instruction are detailed in the individual instruction descriptions in Chapter 3 of this 
manual. 

NOTE 

When a flag is "set* it is set ON (has the value one); 
when a flag is 'reset' it is reset OFF (has the value 
zero). 



Carry Flag 

As its name implies, the carry flag is commonly used to indicate whether an addition causes a 'carry' into the 
next higher older digit. The carry flag is also used as a 'borrow' flag in subtractions, as explained under Two's 
Complement Representation of Data' in Chapter 2 of this manual. The carry flag is also affected by the logical 
AND, OR, an i exclusive OR instructions. These instructions set ON or OFF particular bits of the accumulator. 
See the descriptions of the ANA, ANI, ORA, ORI, XRA, and XRI instructions in Chapter 3. 

The rotate instructions, which move the contents of the accumulator one position to the left or right, treat the 
carry bit as though it were a ninth bit of the accumulator. See the descriptions of the RAL, RAR, RLC, and RRC 
instructions ir Chapter 3 of this manual. 

Example: 

Addition of two one-byte numbers can produce a carry out of the high-order bit: 

Bit Number: 7654 3210 

AE= 1010 1110 
+74- 0111 0100 



0010 0010 = 22 carry flag = 1 

An addition tiat causes a carry out of the high order bit sets the carry flag to 1; an addition that does not cause 
a carry resets the flag to zero. 



Sign Flag 

As explained jnder Two's Complement Representation of Data* in Chapter 2, bit 7 of a result in the accumulator 
can be interpieted as a sign. Instructions that affect the sign flag set the flag equal to bit 7, A zero in bit 7 
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indicates a positive value; a one indicates a negative value. This value is duplicated in the sign flag so that 
conditional lump, call, and return instructions can test for positive and negative values. 



Zero Flag 

Certain instructions set the zero flag to one to indicate that the result in the accumulator contains alt zeros. 
These instructions reset the flag to zero if the result in the accumulator is other than zero. A result that has a 
carry and a zero result also sets the zero bit as shown below: 

1010 0111 
+0101 1001 



0000 0000 Carry Flag - 1 
Zero Flag =1 



Parity flag 



Parity is determined by counting the number of one bits set in the result in the accumulator. Instructions that 
affect the parity flag set the flag to one for even parity and reset the flag to zero to indicate odd parity, 



Auxiliary Carry Flag 

The auxiliary carry flag indicates a carry out of bit 3 of the accumulator. You cannot test this flag directly in 
your program; it is present to enable the DAA (Decimal Adjust Accumulator) to perform its function. 

The auxiliary carry flag and the DAA instruction allow you to treat the value in the accumulator as two 4-bit 
binary coded decimal numbers. Thus, the value 0001 1001 is equivalent to 19. (If this value is interpreted as a 
binary number, it has the value 25.) Notice, however, that adding one to this value produces a non-decimal 
result: 

0001 1001 
+0000 0001 

0001 1010 - 1A 

The DAA instruction converts hexadecimal values such as the A in the preceding example back into binary coded 
decimal (BCD) format. The DAA instruction requires the auxiliary carry flag since the BCD format makes it 
possible for arithmetic operations to generate a carry from the low-order 4-bit digit into the high-order 4-bit 
digit. The DAA performs the following addition to correct the preceding example: 

0001 1010 
+0000 0110 



0001 0000 
+0001 0000 (auxiliary carry) 

0010 0000 = 20 
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The auxiliary carry flag is affected by all add, subtract, increment, decrement, compare, and all logical AND, 
OR, and exclusive OR instructions. (See the descriptions of these instructions tn Chapter 3.) There is some 
difference in the handling of the auxiliary carry flag by the logical AND instructions in the 8080 processor and 
the 8085 processor. The 8085 iogicai AND instructions always set the auxiliary flag ON. The 8080 logical AND 
instructions s-2t the flag to reflect the logical OR of bit 3 of the values involved in the AND operation. 



Stack and Stack Pointer 

To understand the purpose and effectiveness of the stack, it is useful to understand the concept of a subroutine. 

Assume that your program requires a multiplication routine. (Since the 8080 has no multiply instructions, this 
can be performed through repetitive addition. For example, 3x4 is equivalent to 3+3+3+3.) Assume further that 
your program needs this multiply routine several times. You can recode this routine inline each time it is needed, 
but this can use a great deal of memory. Or, you can code a subroutine: 



inline Coding 



Subroutine 



mine routine 



mine routine 



nline routine 



:all 



CALL 





subroutine 



CALL 



The 8080 provides instructions that call and return from a subroutine. When the call instruction is executed, the 
address of tha next instruction (the contents of the program counter) is pushed onto the stack. The contents of 
the program :ounter are replaced by the address of the desired subroutine. At the end of the subroutine, a 
return instruction pops that previously-stored address off the stack and puts it back into the program counter. 
Program execution then continues as though the subroutine had been coded inline. 

The mechanism that makes this possible is, of course, the stack. The stack is simply an area of random access 
memory addressed by the stack pointer. The stack pointer is a hardware register maintained by the processor. 
However, your program must initialize the stack pointer. This means that your program must load the base 
address of the stack into the stack pointer. The base address of the stack is commonly assigned to the highest 
available add'ess in RAM. This is because the stack expands by decrementing the stack pointer. As items are 
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added to the stack, it expands into memory locations with lower addresses. As items are removed from the 
stack, the stack pointer is incremented back toward its base address. Nonetheless, the most recent item on the 
stack is known as the 'top of the stack.* Stack is still a most descriptive term because you can always put 
something else on top of the stack. In terms of programming, a subroutine can call a subroutine, and so on. 
The only limitation to the number of items that can be added to the stack is the amount of RAM available for 
the stack. 

The amount of RAM allocated to the stack is important to the programmer. As you write your program, you 
must be certain that the stack will not expand into areas reserved for other data. For most applications, this 
means that you must assign data that requires RAM to the lowest RAM addresses available. To be more precise, 
you must count up all instructions that add data to the stack. Ultimately, your program should remove from 
the stack any data it places on the stack. Therefore, for any instruction that adds to the stack, you can sub- 
tract any intervening instruction that removes an item from the stack. The most critical factor is the maximum 
size of the stack. Notice that you must be sure to remove data your program adds to the stack. Otherwise, any 
left-over items on the stack may cause the stack to grow into portions of RAM you intend for other data. 



Stack Operations 

Stack operations transfer sixteen bits of data between memory and a pair of processor registers. The two basic 
operations are PUSH, which adds data to the stack, and POP, which removes data from the stack. 

A call instruction pushes the contents of the program counter (which contains the address of the next instruction) 
onto the stack and then transfers control to the desired subroutine by placing its address in the program counter, 
A return instruction pops sixteen bits off the stack and places them in the program counter. This requires the 
programmer to keep track of what is in the stack. For example, if you call a subroutine and the subroutine 
pushes data onto the stack, the subroutine must remove that data before executing a return instruction. Other- 
wise, the return instruction pops data from the stack and places it in the program counter. The results are 
unpredictable, of course, but probably not what you want. 



Saving Program Status 

It is likely that a subroutine requires the use of one or more of the working registers. However, it is equally 
likely that the main program has data stored in the registers that it needs when control returns to the main 
program. As general rule, a subroutine should save the contents of a register before using it and then restore 
the contents of that register before returning control to the main program. The subroutine can do this by 
pushing the contents of the registers onto the stack and then popping the data back into the registers before 
executing a return. The following instruction sequence saves and restores ail the working registers. Notice that 
the POP instructions must be in the opposite order of the PUSH instructions if the data is to be restored to its 
original location. 
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SUBRTN: PUSH PSW 

PUSH B 

PUSH D 

PUSH H 

subroutine coding 



POP 


H 


POP 


D 


POP 


B 


POP 


PSW 


RETURN 



The letters B, D, and H refer to the B and C, D and E, and H and L register pairs, respectively: PSW refers to 
the program siatus word. The program status word is a 16-bit word comprising the contents of the accumulator 
and the five condition flags. (PUSH PSW adds three bits of filler to expand the condition flags into a full 
byte; POP PSW strips out these filler bits.) 



Input/Output Ports 

The 256 inpui /output ports provide communication with the outside world of peripheral devices. The IN and 
OUT instructions initiate data transfers. 

The IN instruction latches the number of the desired port onto the address bus. As soon as a byte of data is 
returned to tre data bus latch, it is transferred into the accumulator. 

The OUT instruction latches the number of the desired port onto the address bus and latches the data in the 
accumulator onto the data bus. 

The specified x>rt number is duplicated on the address bus. Thus, the instruction IN 5 latches the bit configura- 
tion 0000 0K1 0000 0101 onto the address bus. 

Notice that the IN and OUT instructions simply initiate a data transfer. It is the responsibility of the peripheral 
device to dete;t that it has been addressed. Notice also that it is possible to dedicate any number of ports to 
the same peripheral device. You might use a number of ports as control signals, for example. 

Because input and output are almost totally application dependent, a discussion of design techniques is beyond 
the scope of tiis manual. 

For additional hardware information, refer to the 8080 or 8085 Microcomputer Systems User's Manual. 

For related programming information, see the descriptions of the IN, OUT, Dl, El, RST, and RIM and SIM 
instructions in Chapter 3 of this manual. (The RIM and SIM instructions apply only to the 8085.) 
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Instruction Set 



The 8080 incorporates a powerful array of instructions. This section provides a genera! overview of the instruc- 
tion set. The detailed operation of each instruction is described in Chapter 3 of this manual. 



Addressing Modes 

Instructions can be categorized according to their method of addressing the hardware registers and/or memory. 

Implied Addressing, The addressing mode of certain instructions is implied by the instruction's function. For 
example, the STC (set carry flag) instruction deals only with the carry flag; the DAA (decimal adjust accumu- 
lator) instruction deals with the accumulator, 

Register Addressing. Quite a large set of instructions call for register addressing. With these instructions, you 
must specify one of the registers A through E, H or L as well as the operation code. With these instruction; 
the accumulator is implied as a second operand. For example, the instruction CMP E may be interpreted as 
'compare the contents of the E register with the contents of the accumulator. * 



>ns, 



Most of the instructions that use register addressing deal with 8-bit values. However, a few of these instructions 
deal with 16-bit register pairs. For example, the PCHL instruction exchanges the contents of the program counter 
with the contents of the H and L registers. 



immediate Addressing. Instructions that use immediate addressing have data assembled as a part of the instruction 
itself. For example, the instruction CP! 'C may be interpreted as 'compare the contents of the accumulator with 
the letter C. ! When assembled, this instruction has the hexadecimal value FE43. Hexadecimal 43 is the internal 
representation for the letter C. When this instruction is executed, the processor fetches the first instruction byte 
and determines that it must fetch one more byte. The processor fetches the next byte into one of its internal 
registers and then performs the compare operation. 

Notice that the names of the immediate instructions indicate that they use immediate data. Thus, the name of an 
add instruction is ADD; the name of an add immediate instruction is ADI. 

All but two of the immediate instructions use the accumulator as an implied operand, as in the CPI instruction 
shown previously. The MV! (move immediate) instruction can move its immediate data to any of the working 
registers, including the accumulator, or to memory, Thus, the instruction MVI D.OFFH moves the hexadecimal 
value FF to the D register. 

The LXI instruction (load register pair immediate) is even more unusual in that its immediate data is a 16-bit 
value. This instruction is commonly used to load addresses into a register pair. As mentioned previously, your 
program must initialize the stack pointer; LXI is the instruction most commonly used for this purpose. For ex- 
ample, the instruction LXI SP,30FFH loads the stack pointer with the hexadecimal value 30FF, 



Direct Addressing, jump instructions include a 16-bit address as part of the instruction. For example, the 
instruction J MP 1000H causes a jump to the hexadecimal address 1000 by replacing the current contents of the 
program counter with the new value 1000. 



1-15 



Chapter 1. Assembly Langjage and Processors 



Instructions that include a direct address require three bytes of storage: one for the instruction code, and two 
for the 16-bit address. 



Register Indirect Addressing. Register indirect instructions reference memory via a register pair. Thus, the 
instruction MOV M,C moves the contents of the C register into the memory address stored in the H and L 
register pair. "I he instruction LDAX 8 loads the accumulator with the byte of data specified by the address 
in the B and C register pair. 



Combined Addressing Modes. Some instructions use a combination of addressing modes. A CALL instruction, 
for example, combines direct addressing and register indirect addressing. The direct address in a CALL instruction 
specifies the address of the desired subroutine; the register indirect address is the stack pointer. The CALL 
instruction pushes the current contents of the program counter into the memory location specified by the stack 
pointer. 

Timing Effects of Addressing Modes. Addressing modes affect both the amount of time required for executing 
an instruction and the amount of memory required for its storage. For example, instructions that use implied or 
register addressing execute very quickly since they deal directly with the processor hardware or with data already 
present in hardware registers. More important, however, is that the entire instruction can be fetched with a 
single memory access. The number of memory accesses required is the single greatest factor in determining 
execution timing. More memory accesses require more execution time. A CALL instruction, for example, requires 
five memory accesses: three to access the entire instruction, and two more to push the contents of the program 
counter onto ihe stack. 

The processor can access memory once during each processor cycle. Each cycle comprises a variable number of 
states. (The individual instruction descriptions in Chapter 3 specify the number of cycles and states required for 
each instruction.) The length of a state depends on the clock frequency specified for your system, and may 
range from 480 nanoseconds to 2 microseconds. Thus, the timing of a four state instruction may range from 
1.920 microseconds through 8 microseconds. (The 8085 has a maximum clock frequency of 320 nanoseconds 
and therefore :an execute instructions about 50% faster than the 8080.) 



instruction Naming Conventions 

The mnemonit s assigned to the instructions are designed to indicate the function of the instruction. The instruc- 
tions fail into the following functional categories: 

Data Transfer Group. The data transfer instructions move data between registers or between memory and 

registers. 

MOV Move 

MVI Move immediate 

LDA Load Accumulator Directly from Memory 

5TA Store Accumulator Directly in Memory 

LHLD Load H and L Registers Directly from Memory 

SHLD Store H and L Registers Directly in Memory 

ALL MNEMONICS© 1974, 1975, 1976, 1977 INTEL CORPORATION 
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An 'X' in the name of a data transfer instruction implies that it deals with a register pair: 

LXI Load Register Pair with Immediate data 

LDAX Load Accumulator from Address in Register Pair 

STAX Store Accumulator in Address in Register Pair 

XCHG Exchange H and L with D and E 

XTHL Exchange Top of Stack with H and L 



Arithmetic Group. The arithmetic instructions add, subtract, increment, or decrement data in registers or 
memory, 



ADD 

ADl 

ADC 

ACI 

SUB 

SUI 

SBB 

SBI 

INR 

DCR 

INX 

DCX 

DAD 



Add to Accumulator 

Add Immediate Data to Accumulator 

Add to Accumulator Using Carry Flag 

Add Immediate Data to Accumulator Using Carry Flag 

Subtract from Accumulator 

Subtract Immediate Data from Accumulator 

Subtract from Accumulator Using Borrow (Carry) Flag 

Subtract Immediate from Accumulator Using Borrow 

Increment Specified Byte by One 

Decrement Specified Byte by One 

Increment Register Pair by One 

Decrement Register Pair by One 

Double Register Add: Add Contents of Register 

Pair to H and L Register Pair 



Logical Group. This group performs logical (Boolean) operations on data in registers and memory and on 
condition flags. 

The logical AND, OR, and Exclusive OR instructions enable you to set specific bits in the accumulator ON or 
OFF, 



ANA 

AN I 

ORA 

ORI 

XRA 

XRI 



Logical AND with Accumulator 

Logical AND with Accumulator Using Immediate Data 

Logical OR with Accumulator 

Logical OR with Accumulator Using Immediate Data 

Exclusive Logical OR with Accumulator 

Exclusive OR Using Immediate Data 



The compare instructions compare the contents of an 8-bit value with the contents of the accumulator: 



CMP 
CPI 



Compare 

Compare Using Immediate Data 
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The rotate instructions shift the contents of the accumulator one bit position to the left or right: 

RLC Rotate Accumulator Left 

RRC Rotate Accumulator Right 

RAL Rotate Left Through Carry 

RAR Rotate Right Through Carry 

Complement a id carry flag instructions: 

CMA Complement Accumulator 

CMC . Complement Carry Flag 

5TC Set Carry Flag 



Branch Group. The branching instructions alter normal sequential program fiow, either unconditionally or 
conditionally, The unconditional branching instructions are as follows: 



JMP 


Jump 


CALL 


Call 


RET 


Return 



Conditional branching instructions examine the status of one of four condition flags to determine whether the 
specified branch is to be executed. The conditions that may be specified are as follows: 

NZ Not Zero (Z = 0) 

Z Zero (Z - 1 ) 

NC No Carry (C = 0) 

C Carry (C = 1 ) 

?0 Parity Odd (P = 0) 

PE Parity Even (P = 1) 

P Plus (S = 0) 

M Minus (S - 1) 

Thus, the conditional branching instructions are specified as follows: 

jumps Calls Returns 



JC 


CC 


RC 


(Carry) 


JNC 


CNC 


RNC 


(No Carry) 


JZ 


CZ 


RZ 


(Zero) 


JNZ 


CNZ 


RNZ 


(Not Zero) 


JP 


CP 


RP 


(Pius) 


JM 


CM 


RM 


(Minus) 


JPE 


CPE 


RPE 


(Parity Even) 


JPO 


CPO 


RPO 


(Parity Odd) 



Two other instructions can effect a branch by replacing the contents of the program counter: 

PCHL Move H and L to Program Counter 

RST Special Restart Instruction Used with Interrupts 
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Stack, I/O, and Machine Control Instructions. The following instructions affect the stack and/or stack pointer 

PUSH Push Two Bytes of Data onto the Stack 

POP Pop Two Bytes of Data off the Stack 

XTHL Exchange Top of Stack with H and L 

SPHL Move contents of H and L to Stack Pointer 

The I/O instructions are as follows: 

IN Initiate Input Operation 

OUT Initiate Output Operation 

The machine control instructions are as follows: 

El Enable Interrupt System 

Dl Disable Interrupt System 

HLT Halt 

NOP No Operation 



HARDWARE/INSTRUCTION SUMMARY 

The following illustrations graphically summarize the instruction set by showing the hardware acted upon by 
specific instructions. The type of operand allowed for each instruction is indicated through the use of a code. 
When no code is given, the instruction does not allow operands. 

Code Meaning 

REGMg The operand may specify one of the 8-bit registers A,B.CD,E,H, or L or M 

(a memory reference via the 16-bit address in the H and L registers). The 
MOV instruction, which calls for two operands, can specify M for only one 
of its operands. 

Do Designates 8-bit immediate operand. 

A-jg Designates a 16-bit address. 

Po Designates an 8-bit port number, 

REG 16 Designates a 16-bit register pair (B&C,D&E,H&L, or SP). 

Dig Designates a 16-bit immediate operand. 



Accumulator Instructions 

The following illustration shows the instructions that can affect the accumulator. The instructions listed above 
the accumulator all act on the data in the accumulator, and all except CMA (complement accumulator) affect 
one or more of the condition flags. The instructions listed below the accumulator move data into or out of the 
accumulator, but do not affect condition flags. The STC (set carry) and CMC (complement carry) instructions 
are also shown here. 
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ADD\ ADI\ 

ADC AC I 

SUB SUt 

5BB I SBI 

ANA ) REGM 8 AN! 

XRA XRI 

ORA ORI 

CMP/ CPI ) 

RLC RAL RRC 

RAR CMA DAA 
!NR \ 

DCR/ REGM 8 



) D Q 



MOV REGM Q ,RECM< 



LDAXI . 
ST AX 



> EC.DE 



ACCUMULATOR 


FLAGS 




B 


C 




D 


E 




H 


L 



STC CMC 



HIGH 



LOW 



STACK 



POINTER 



PROGRAM ! COUNTER 



lda! 

STAJ A 16 
MV! [» 

o 

MOV F:EGM ftl REG 



MEMORY 



STACK 



INPo 



OUT P g 



INPUT 
PORTS 



OUTPUT 
PORTS 
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Register Pair (Word) Instructions 

The following instructions all deal with 16-bit words. Except for DAD (which adds the contents of the B&C or 
D&E register pair to H&L), none of these instructions affect the condition flags. DAD affects only the carry 
flag. 



ACCUMULATOR 


FLAGS 



/ 



B 


C 



D 


E 



INX \ HiGH 

DCX > REG 16 rSPHL-*- 
DAD/I 



LOW 



XCHG 



STACK 



POINTER 



PCHL- 



PROGRAM i COUNTER 



XTHL- 



LHLD 
SHLD 



LXI REG^D^ 
16 16 



MEMORY 



STACK 



PUSH 
POP 



} B.D.HJ 



PSW 
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Branching Instructions 



The following instructions can alter the contents of the program counter, thereby altering the normal sequential 
execution flow, jump instructions affect only the program counter. Call and Return instructions affect the 
program counter, stack pointer, and stack. 



ACCUMULATOR 



FLAGS 



C 



{} 


E 



PCHL- 



HIGH 


LOW 




STACK 


POINTER 




-*-RST 






PROGRAM 


COUNTER 


t \ 



IMP 

JC jNC 
JZ JNZ 
IP JM f 
IPE JPO i 



x 16 



CALL 



RET 



cc 


CNC 


CZ 


CNZ 


CP 


CM 


CPE CPO 



> A 



16 



RC 


RNC 


RZ 


RNZ 


RP 


RM 


RPE 


RPO 



>A 



16 



MEMORY 



STACK 



CONTROL INSTRUCTIONS 

RST 

NOP 

HLT 

El 

Dl 

SIM 

RIM. 



8085 only 
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The following is a summary of the instruction set: 



ADD 

ADC 

SUB 

SBB 

ANA 

XRA 

ORA 

CMP 



\ REGMg 



AD1 
ACI 
SUI 
SB1 
ANi 
XR! 
OR1 
CPI 



RLC RAL RRC 
RAR CMA DAA 

INRl 

DCRf 



REGM Q 



-^ACCUMULATOR 



MOV REGM Q; REGMn 



B 



LXIREG l6 ,D 16 r 



FLAGS 



|STC CMC 
rMNX') 

dcxIreg 



HIGH 



LOW 






16 



XCHG 



SPHL H STACK j POINTER \ + 

PCHL» fPROGRAM I COUNTER | ^-RST 



-XTHL — I 



JMP 

jC JNC 

JZ JNZ 

JP JM I 

JPE JPOj 



M6 



/ LDAXl 
STAXJ 

LDA^ 
STAJ 



LHLD 
STHD 



16 



BC.DE 



16 



MV! Dg 

MOV REGMg,REGM g 

CODE 



MEMORY 



STACK 



INP 



OUT P 



INPUT 
PORTS 



OUTPUT 
PORTS 



PUSH 
' POP 



B,D,H,PSW 



CALL 




RET 


CC 


CNC") 




RC 


RNC"| 


cz 

CP 


CNZ I 
CM r 
CPOJ 


A 16 


RZ 
RP 


RNZ v 

RPOJ 


CPE 




RPE 




CONTROL 








INSTRUCTIONS 






RST 










NOP 










HLT 










Ei 










Dl 










sim! 
rimJ 


8085 ONLY 



MEANING 



REGM C 



D 8 

A 16 

P 8 
REG 

D 16 



16 



The operand may specify one of the 8-bit registers A,B,C,D,E,H, or L or M (a memory 

reference via the 16-bit address in the H and L registers). The MOV instruction, which 

calls for two operands, can specify M for only one of its operands. 

Designates 8-bit immediate operand. 

Designates a 16-bit address. 

Designates an 8-bit port number. 

Designates a 16-bit register pair (B&C,D&E,H&L,or SP). 

Designates a 16 -bit immediate operand. 
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8085 PROCESSOR DIFFERENCES 

The differences between the 8080 processor and the 8085 processor will be more obvious to the system designer 
than to the programmer. Except for two additional instructions, the 8085 instruction set is identical to and fully 
compatible with the 8080 instruction set. Most programs written for the 8080 should operate on the 8085 with- 
out modification. The only programs that may require changes are those with critical timing routines; the higher 
system speed of the 8085 may alter the time values of such routines. 

A partial listing of 8085 design features includes the following: 

o A single 5 volt power supply, 

9 Execution speeds approximately 50% faster than the 8080. 

& Incorporation in the processor of the features of the 8224 Clock Generator and Driver and the 

8228 System Controller and Bus Driver, 

o A non-maskable TRAP interrupt for handling serious problems such as power failures. 

o Three separately maskable interrupts that generate internal RST instructions. 

e Input/output tines for serial data transfer, 



Programming for the 8085 

For the programmer, the new features of the 8085 are summarized in the two new instructions SIM and RIM. 
These instructions differ from the 8080 instructions in that each has multiple functions. The SIM instruction 
sets the interrupt mask and/or writes out a bit of serial data. The programmer must place the desired interrupt 
mask and/or serial output in the accumulator prior to execution of the SIM instruction. The RIM instruction 
reads a bit o serial data if one is present and the interrupt mask into the accumulator. Details of these instruc- 
tions are covered in Chapter 3. 

Despite the new interrupt features of the 8085, programming for interrupts is little changed. Notice, however, that 
8085 hardware interrupt RESTART addresses fall between the existing 8080 RESTART addresses. Therefore, 
only four bytes are available for certain RST instructions. Also, the TRAP interrupt input is non-maskable and 
cannot be disabled. If your application uses this input, be certain to provide an interrupt routine for it. 

The interrupt have the following priority; 

TRAP highest 

RST7.5 

RST6.5 

RST5.5 

INTR lowest 

When more han one interrupt is pending, the processor always recognizes the higher priority interrupt first. 
These priorhies apply only to the sequence in which interrupts are recognized. Program routines that service 
interrupts hive no special priority. Thus, an RST5.5 interrupt can interrupt the service routine for an RST7.5 
interrupt. If you want to protect a service routine from interruption, either disable the interrupt system (Dl 
instruction), or mask out other potential interrupts (SIM instruction). 
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Conditional Instructions 

Execution of conditional instructions on the 8085 differs from the 8080. The 8080 fetches all three instruction 
bytes whether or not the condition is satisfied. The 8085 evaluates the condition while it fetches the second 
instruction byte. If the specified condition is not satisfied, the 8085 skips over the third instruction byte and 
immediately fetches the next instruction. Skipping the unnecessary byte allows for faster execution. 
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2. ASSEMBLY LANGUAGE CONCEPTS 



INTRODUCTION 



just as the English language has its rules of grammar, assembly language has certain coding rules. The source line 
is the assembly language equivalent of a sentence. 

This assembler recognizes three types of source lines: instructions, directives, and controls. This manual describes 
instructions and directives. Controls are described in the operator's manual for your version of the assembler. 

This chapter describes the general rules for coding source lines. Specific instructions (see Chapter 3) and 
directives (see Chapters 4 and 5) may have specific coding rules. Even so, the coding of such instructions and 
directives must conform to the general rules in this chapter. 



SOURCE LINE FORMAT 

Assembly language instructions and assembler directives may consist of up to four fields, as follows: 

( Label: i^ Opcode Operand ;Comment 

[Name ( 

The fields may be separated by any number of blanks, but must be separated by at least one delimiter. Each 
instruction and directive must be entered on a single line terminated by a carriage return and a line feed. No 
continuation lines are possible, but you may have lines consisting entirely of comments. 



Character Set 

The following characters are legal in assembly language source statements: 

The letters of the alphabet, A through Z. Both upper- and lower-case letters are allowed. Internally, 
the assembler treats ail letters as though they were upper-case, but the characters are printed exactly 
as they were input in the assembly listing. 

" « The digits through 9, 

© The following special characters: 
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Character 



Meaning 



/ 
\ 

> 

% 
I 

blank 



CR 
FF 
HI 



Plus sign 

Minus sign 

Asterisk 

Siash 

Comma 

Left parenthesis 

Right parenthesis 

Single quote 

Ampersand 

Colon 

Dollar sign 

Commercial 'at' sign 

Question mark 

Equal sign 

Less than sign 

Greater than sign 

Percent sign 

Exclamation point 

Biank or space 

Semicolon 

Period 

Carriage return 

Form feed 

Horizontal tab 



in addition, any ASCII character may appear in a string enclosed in single quotes or in a comment. 



Delimiters 

Certain characters have special meaning to the assembler in that they function as delimiters. Delimiters define 
the end of a vource statement, a field, or a component of a field. The following list defines the delimiters 
recognized by the assembler. Notice that many delimiters are related to the macro feature explained in Chapter 
5. Delimiters jsed for macros are shown here so that you will not accidentally use a delimiter improperly. 
Refer to Chapter 5 for a description of macros. 



2-2 



Chapter 2. Assembly Language Concepts 



Character(s) 
blank 



Meaning 

one or more 
blanks 



Use 



field separator or symbol terminator 



pair of single 
quote characters 

pair of paren- 
theses 



separate operands in the operands field, 
including macro parameters 

delimit a character string 



delimit an expression 



CR 

HT 



<~> 



carnage return 
horizontal tab 
semicolon 
colon 
ampersand 



pair of angle 

brackets 



percent sign 



exclamation 
point 



double semi- 
colon 



statement terminator 

field separator or symbol terminator 

comment field delimiter 

delimiter for symbols used as labels 

delimit macro prototype text or formal 
parameters for concatenation 

delimit macro parameter text which 
contains commas or embedded blanks; 
also used to delimit a parameter list 

delimit a macro parameter that is to be 
evaluated prior to substitution 

an escape character used to pass the 
following character as part of a macro 
parameter when the character might 
otherwise be interpreted as a delimiter 

delimiter for comments in macro definitions 
when the comment is to be suppressed when 
the macro is expanded 



Label/Name Field 

Labels are always optional. An instruction label is a symbol name whose value is the location where the instruc- 
tion is assembled. A label may contain from one to six alphanumeric characters, but the first character must be 
alphabetic or the special characters '?' or '@\ The label name must be terminated with a colon. A symbol used 
as a label can be defined only once in your program. (See 'Symbols and Symbol Tables' later in this chapter.) 
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Alphanumeric, characters incfude the letters of the alphabet, the question mark character, and the decimal 
digits through 9. 

A name is required for the SET, EQU, and MACRO directives. Names follow the same coding rules as labels, 
except that tiey must be terminated with a blank rather than a colon. The label/name field must be empty for 
the LOCAL ,\nd ENDM directives. 



Opcode Field 

This required field contains the mnemonic operation code for the 8080/8085 instruction or assembler directive 
to be perforned. 



Operand Field 

The operand field identifies the data to be operated on by the specified opcode. Some instructions require no 
operands. Otners require one or two operands. As a general rule, when two operands are required (as in data 
transfer and arithmetic operations), the first operand identifies the destination (or target) of the operation's 
result, and the second operand specifies the source data. 



Examples: 



MO*/ A.C ;MOVE CONTENTS OF REG C TO ACCUMULATOR 

MV A/B' ;MOVE B TO ACCUMULATOR 



Comment Field 



The optiona comment field may contain any information you deem useful for annotating your program. The 
only coding requirement for this field is that it be preceded by a semicolon. Because the semicolon is a delimiter, 
there is no need to separate the comment from the previous field with one or more spaces. However, spaces are 
commonly used to improve the readability of the comment. Although comments are always optional, you should 
use them liberally since it is easier to debug and maintain a well documented program. 



CODING OPERAND FIELD INFORMATION 

There are four types of information (a through d in the following list) that may be requested as items in the 
operand fiel i; the information may be specified in nine ways, each of which is described below. 
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OPERAND FIELD INFORMATION 

Information required Ways of specifying 



(a) 


Register 


(D 


Hexadecimal Data 


(b) 


Register Pair 


(2) 


Decimal Data 


(c) 


immediate Data 


(3) 


Octal Data 


(d) 


16-bit Address 


(4) 


Binary Data 






(5) 


Location Counter ($) 






(6) 


ASCII Constant 






(7) 


Labels assigned values 






(8) 


Labels of instructions 






(9) 


Expressions 



Hexadecimal Data. Each hexadecimal number must begin with a numeric digit (0 through 9) and must be 
followed by the letter H. 

Label Opcode Operand Comment 

HERE: MVI C.OBAH ;LOAD REG C WITH HEX BA 

Decimal Data. Each decimal number may be identified by the letter D immediately after its last digit or may 
stand alone. Any number not specifically identified as hexadecimal, octal, or binary is assumed to be decimal. 
Thus, the following statements are equivalent: 



Label 


Opcode 


Operand 


Comment 


ABC: 


MVI 


E.15 


;LOAD E WITH 15 DECIMAL 




MVI 


E.15D 





Octal Data. Each octal number must be followed by the letter or the letter Q. 
Label Opcode Operand Comment 

LABEL: MV! A.72Q ;LOAD OCTAL 72 INTO ACCUM 

Binary Data. Each binary number must be followed by the letter B. 

Label Opcode Operand Comment 

NOW: MVI D,ni10110B ;LOAD REGISTER D 

;W!TH 0F6H 
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Location Counter, The $ character refers to the current location counter. The location counter contains the 
address where the current instruction or data statement will be assembled. 

Label Opcode Operand Comment 

GO: J MP $+6 ;jUMP TO ADDRESS 6 BYTES BEYOND 

;THE FIRST BYTE OF THIS 
INSTRUCTION 



ASCII Const wt. One or more ASCII characters enclosed in single quotes define an ASCII constant. Two 
successive single quotes must be used to represent one single quote within an ASCII constant. 

t.abel Opcode Operand Comment 

MVI E,'*' ;LOAD E REG WITH 8-BIT ASCII 

REPRESENT ATION OF * 
DATE: DB TODAY"S DATE' 



Labels Assigned Values. The SET and EQU directives can assign values to labels. In the following example, 
assume that VALUE has been assigned the value 9FH; the two statements are equivalent: 



Abel 


Opcode 


Operand 


Comment 


M: 


MVI 


D.9FH 




\2: 


MVI 


D.VALUE 





Labels of Instruction or Data. The label assigned to an instruction or a data definition has as its value the 
address of the first byte of the instruction or data. Instructions elsewhere in the program can refer to this 
address by i:s symbolic label name. 

iabei Opcode Operand Comments 

HERE: jMP THERE ;jUMP TO INSTRUCTION AT THERE 

THERE: MVI D.9FH 



Expressions. All of the operand types discussed previously can be combined by operators to form an expression. 
In fact, the example given for the location counter ($+6) is an expression that combines the location counter 
with the decimal number 6. 

Because the rules for coding expressions are rather extensive, further discussion of expressions is deferred until 

later in this chapter. 



2-6 



Chapter 2. Assembly Language Concepts 



Instructions as Operands. One operand type was intentionally omitted from the list of operand field infor- 
mation: Instructions enclosed in parentheses may appear in the operands field. The operand has the value of 
the left-most byte of the assembled instruction. 

Label Opcode Operand 

INS: DB (ADD C) 

The statement above defines a byte with the value 81 H (the object code for an ADD C instruction). Such 
coding is typically used where the object program modifies itself during execution, a technique that is strongly 
discouraged. 



Register-Type Operands. Only instructions that allow registers as operands may have register-type operands. 
Expressions containing register-type operands are flagged as errors. Thus, an instruction like 

JMP A 

is flagged as an illegal use of a register. 

The only assembler directives that may contain register-type operands are EQU, SET, and actual parameters in 
macro calls. Registers can be assigned alternate names only by EQU or SET. 

TWO'S COMPLEMENT REPRESENTATION OF DATA 

Any 8-bit byte contains one of the 256 possible combinations of zeros and ones. Any particular combination may 
be interpreted in a number of ways. For example, the code 1 FH may be interpreted as an instruction (Rotate 
Accumulator Right Through Carry), as the hexadecimal value 1 F, the decimal value 31, or simply the bit 
pattern 0001 1111. 

Arithmetic instructions assume that the data bytes upon which they operate are in the 'two's complement' 
format. To understand why, let us first examine two examples of decimal arithmetic: 

35 35 

-12 +88 

23 123 

Notice that the results of the two examples are equal if we disregard the carry out of the high order position in 
the second example. The second example illustrates subtraction performed by adding the ten's complement of 
the subtrahend (the bottom number) to the minuend (the top number). To form the ten's complement of a 
decimal number, first subtract each digit of the subtrahend from 9 to form the nine's complement; then add one 
to the result to form the ten's complement. Thus, 99-12=87; 87+1=88, the ten's complement of 12. 

The ability to perform subtraction with a form of addition is a great advantage in a computer since fewer cir- 
cuits are required. Also, arithmetic operations within the computer are binary, which simplifies matters even more. 
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The processoi forms the two's complement of a binary value simply by reversing the value of each bit and then 
adding one tc the result. Any carry out of the high order bit is ignored when the complement is formed. Thus, 
the subtraction shown previously is performed as foilows: 

35 = 0010 0011 0010 0011 

-j2_ = oooo iioo = mi oon +iiii oioo 

23 + 1 1 0001 0111 =23 

1111 0100 

Again, by discarding the carry out of the high order position, the subtraction is performed through a form of 
addition. However, if this operation were performed by the 8080 or the 8085, the carry flag would be set OFF 
at the end of the subtraction. This is because the processors complement the carry flag at the end of a subtract 
operation so :hat it can be used as a 'borrow' flag in multibyte subtractions, in the example shown, no borrow 
is required, s<> the carry flag is set OFF, By contrast, the carry flag is set ON if we subtract 35 from 12: 

12 - 0000 1100 0000 1100 

-35 = 0010 0011=1101 1100 +1101 1101 

+ 1 1110 1001 = 233 or -105 



1101 1101 



In this case, ihe absence of a carry indicates that a borrow is required from the next higher order byte, if any. 
Therefore, tha processor sets the carry flag ON. Notice also that the result is stored in a complemented form. 
If you want o interpret this result as a decimal value, you must again form its two's complement: 

1110 1001 = 0001 0110 

+ 1 

0001 0111 = 23 

Two's complement numbers may also be signed. When a byte is interpreted as a signed two's complement number, 
the high order bit indicates the sign. A zero in this bit indicates a positive number, a one a negative number. The 
seven low order bits provide the magnitude of the number. Thus, 0111 1111 equals +127 = 

At the beginning of this description of two's complement arithmetic, it was stated that any 8-bit byte may con- 
tain one of me 256 possible combinations of zeros and ones. It must also be stated that the proper interpretation 
of data is a f rpgramming responsibility, 

As an example, consider the compare instruction. The compare logic considers only the raw bit values of the 
items being compared. Therefore, a negative two's complement number always compares higher than a positive 
number, bee .use the negative number's high order bit is always ON. As a result, the meanings of the flags set by 
the compare instruction are reversed. Your program must account for this condition. 
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SYMBOLS AND SYMBOL TABLES 

Symboiic Addressing 

If you have never done symbolic programming before, the following analogy may help clarify the distinction 
between a symbolic and an absolute address. 

The locations in program memory can be compared to a cluster of post office boxes. Suppose Richard Roe 
rents box 500 for two months. He can then ask for his letters by saying 'Give me the mail in box 500,' or 
'Give me the mail for Roe/ If Donald Smith later rents box 500, he too can ask for his maii by either box 
number 500 or by his name. The content of the post office box can be accessed by a fixed, absolute address 
(500) or by a symbolic, variable name. The postal clerk correlates the symboiic names and their absolute values 
m his log book. The assembler performs the same function, keeping track of symbols and their values in a 
symbol table. Note that you do not have to assign values to symbolic addresses. The assembler references its 
location counter during the assembly process to calculate these addresses for you. (The location counter does 
for the assembler what the program counter does for the microcomputer. It tells the assembler where the next 
instruction or operand is to be placed in memory.) 

Symbol Characteristics 

A symbol can contain one to six alphabetic (A-Z) or numeric (0-9) characters (with the first character alphabetic) 
or the special character '?' or *@\ A dollar sign can be used as a symbol to denote the value currently in the 
location counter. For example, the command 

jMP -$+6 

forces a jump to the instruction residing six memory locations higher than the jMP instruction. Symbols of the 
form ; ??nnn' are generated by the assembler to uniquely name symbols local to macros. 

The assembler regards symbols as having the following attributes: reserved or user-defined; global or limited; 
permanent or redefinable; and absolute or relocatable. 



Reserved, User-Defined, and Assembler-Generated Symbols 

Reserved symbols are those that already have special meaning to the assembler and therefore cannot appear as 
user-defined symbols. The mnemonic names for machine instructions and the assembler directives are all reserved 
symbols. 
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The following instruction operand symbols are also reserved: 



Symbol 



Meaning 



C 

D 

E 

H 

L 

SP 

PSW 

M 

STACK 

MEMORY 



Location counter reference 

Accumulator register 

Register B or register pair B and C 

Register C 

Register D or register pair D and E 

Register E 

Register H or register pair H and L 

Register L 

Stack pointer register 

Program status word (Contents of A and status flags) 

Memory reference code using address in H and L 

Special repeatability feature 

Special relocatabiiity feature 



NOTE 

The STACK and MEMORY symbols are fully discussed 
in Chapter 4. 

User-defined <ymbols are symbols you create to reference instruction and data addresses. These symbols are 
defined when they appear in the label field of an instruction or in the name field of EQU, SET, or MACRO 
directives (see Chapters 4 and 5). 

Assembler-gererated symbols are created by the assembler to replace user-defined symbols whose scope is limited 
to a macro dtfinition. 



Global and Limred Symbols 

Most symbols are global. This means that they have meaning throughout your program. Assume, for example, 
that you assign the symbolic name RTN to a routine. You may then code a jump or a call to RTN from any 
point in your program. If you assign the symbolic name RTN to a second routine, an error results since you 
have given multiple definitions to the same name. 

Certain symbols have meaning only within a macro definition or within a call to that macro; these symbols are 
'local' to the macro. Macros require local symbols because the same macro may be used many times in the 
program. If the symbolic names within macros were global, each use of the macro (except the first) would cause 
multiple definitions for those symbolic names. 

See Chapter :i for additional information about macros. 
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Permanent and Redefinabie Symbols 

Most symbols are permanent since their value cannot change during the assembly operation. Only symbois 
defined with the SET and MACRO assembler directives are redefinabie. 



Absolute and Relocatable Symbols 

An important attribute of symbois with this assembler is that of repeatability. Relocatable programs are 
assembled relative to memory location zero. These programs are iater relocated to some other set of memory 
locations. Symbols with addresses that change during relocation are relocatable symbols. Symbols with 
addresses that do not change during relocation are absolute symbols. This distinction becomes important when 
the symbols are used within expressions, as will be explained later. 

External and public symbols are special types of relocatable symbols. These symbois are required to establish 
program linkage when several relocatable program modules are bound together to form a single application 
program. External symbols are those used in the current program module, but defined in another module. 
Such symbois must appear in an EXTRN statement, or the assembler will flag them as undefined. 

Conversely, PUBLIC symbols are defined in the current program module, but may be accessed by other 
modules. The addresses for these symbols are resolved when the modules are bound together. 

Absolute and relocatable symbois may both appear in a relocatable module. References to any of the assembler- 
defined registers A through E, H and L, PSW, SP, and M are absolute since they refer to hardware locations. 
But these references are valid in any module. 



ASSEMBLY-TIME EXPRESSION EVALUATION 

An expression is a combination of numbers, symbols, and operators. Each element of an expression is a term. 

Expressions, like symbois, may be absolute or relocatable. For the sake of readers who do not require the 
relocation feature, absolute expressions are described first. However, users of relocation should read all the 
following. 



Operators 

The assembler includes five groups of operators which permit the following assembly-time operations: arithmetic 
operations, shift operations, logical operations, compare operations, and byte isolation operations. It is important 
to keep in mind that these are all assembly-time operations. Once the assembler has evaluated an expression, it 
becomes a permanent part of your program. Assume, for example, that your program defines a list of ten con- 
stants starting at the label LIST; the following instruction loads the address of the seventh item in the list into 
the H and L registers: 

LXi H.LIST+6 
Notice that LIST addresses the first item, LIST+1 the second, and so on. 
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Arithmetic Operctors 

The arithmetic operators are as follows: 
Operator 
+ 

! 
MOD 



Meaning 

Unary or binary addition 

Unary or binary subtraction 

Multiplication 

Division. Any remainder is discarded (7/2=3). 

Division by zero causes an error. 

Modulo. Result is the remainder caused by a 

division operation. (7 MOD 3=1) 



Examples: 

The following expressions generate the bit pattern for the ASCII character A: 

5+30*2 

(25/5)+30*2 

5+(-30*-2) 

Notice that the MOD operator must be separated from its operands by spaces: 

NUMBR MOD 8 

Assuming tha. NUMBR has the value 25, the previous expression evaluates to the value 



Shift Operators 

The shift operators are as follows: 
Operator 
y SHR x 
y SHL x 



Meaning 

Shift operand V to the right V bit positions. 

Shift operand 'y r to the left V bit positions. 



The shift operators do not wraparound any bits shifted out of the byte. Bit positions vacated by the shift 
operation arc zero-filled. Notice that the shift operator must be separated from its operands by spaces. 

Example: 

Assume that NUMBR has the value 0101 0101. The effects of the shift operators is as follows: 

NUMBR SHR 2 0001 0101 

NUMBR SHL 1 1010 1010 
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Notice that a shift one bit position to the left has the effect of multiplying a value by two; a shift one bit 
position to the right has the effect of dividing a value by two. 



Logical Operators 

The logical operators are as follows: 
Operator 
NOT 
AND 
OR 
XOR 



Meaning 

Logical one's complement 

Logical AND (=1 if both ANDed bits are 1) 

Logical OR (=1 if either ORed bit is 1) 

Logical EXCLUSIVE OR (=1 if bits are different) 



The logical operators act only upon the least significant bit of values involved in the operation. Also, these 
operators are commonly used in conditional IF directives. These directives are fully explained in Chapter 4. 

Example: 

The following IF directive tests the least significant bit of three items. The assembly language code that follows 
the IF is assembled only if the condition is TRUE. This means that all three fields must have a one bit in the 
least significant bit position. 

IF FLDI AND FLD2 AND FLD3 



Compare Operators 

The compare operators are as follows: 

Operator 

EQ 
NE 
LT 
LE 
GT 
GE 
NUL 



Meaning 

Equal 

Not equal 

Less than 

Less than or equal 

Greater than 

Greater than or equal 

Special operator used to test for null (missing) macro 

parameters 
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The compare operators yieid a yes-no result. Thus, if the evaluation of the relation is TRUE, the value of the 
result is all ores. If false, the value of the result is all zeros. Relational operations are based strictly on magni- 
tude comparisons of bit values. Thus, a two's complement negative number (which always has a one in its high 
order bit) is g -eater than a two's complement positive number (which always has a zero in sts high order bit). 

Since the NUL operator applies only to the macro feature, NUL is described in Chapter 5. 

The compare operators are commonly used in conditional IF directives. These directives are fully explained in 
Chapter 4. 

Notice that the compare operator must be separated from its operands by spaces. 
Example: 

The following IF directive tests the values of FLD1 and FLD2 for equality, If the result of the comparison is 
TRUE, the assembly language coding following the IF directive is assembled. Otherwise, the code is skipped over. 

IF FLD1 EQ FLD2 



Byte Isolation aerators 

The byte isol ition operators are as follows: 

Operator Meaning 

HIGH isolate high-order 8 bits of 16-bit value 

LOW Isolate low-order 8 bits of 16-bit value. 

The assemble- treats expressions as 16-bit addresses. In certain cases, you need to deal only with a part of an 
address, or you need to generate an 8-bit value. This is the function of the HIGH and LOW operators. 

The assembler's relocation feature treats all external and relocatable symbols as 16-bit addresses. When one of 
these symbol i appears in the operand expression of an immediate instruction, it must be preceded by either the 
HIGH or LOW operator to specify which byte of the address is to be used in the evaluation of the expression. 
When neithei operator is present, the assembler assumes the LOW operator and issues an error message. 

NOTE 

Any program segment containing a symbol used as the 
argument of a HIGH operator should be located only on 
a page boundary, This is done using the PAGE option 
with the CSEG or DSEG directives described in Chapter 
4. Carries are not propagated from the low-order byte 
when the assembler object code is relocated and the 
carry flag will be lost. Using PAGE ensures that this 
flag is 0. 
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Examples: 

Assume that ADRS is an address manipulated at assembly-time for building tables or lists of items that must all 
be below address 255 in memory, The following IF directive determines whether the high-order byte of ADRS 
is zero, thus indicating that the address is still less than 256: 

IF HIGH ADRS EQ 



Permissible Range of Values 

Internally, the assembler treats each term of an expression as a two-byte, 16-bit value. Thus, the maximum 
range of values is OH through OFFFFH. All arithmetic operations are performed using unsigned two's comple- 
ment arithmetic. The assembler performs no overflow detection for two-byte values, so these values are evaluated 
modulo 64K. 

Certain instructions require that their operands be an eight-bit value. Expressions for these instructions must 
yield values in the range -256 through +255. The assembler generates an error message if an expression for one 
of these instructions yields an out-of-range value. 



NOTE 

Only instructions that allow registers as operands may have 
register-type operands. Expressions containing register-type 
operands are flagged as errors. The only assembler directives 
that may contain register-type operands are EQU, SET, and 
actual parameters in macro calls. Registers can be assigned 
alternate names only by EQU or SET. 



Precedence of Operators 

Expressions are evaluated left to right. Operators with higher precedence are evaluated before other operators 
that immediately precede or follow them. When two operators have equal precedence, the left-most is evaluated 
first. 

Parentheses can be used to override normal rules of precedence. The part of an expression enclosed in paren- 
theses is evaluated first, if parentheses are nested, the innermost are evaluated first. 

15/3 + 18/9 =5 + 2 = 7 

15/(3 + 18/9) = 15/(3 + 2} = 15/5 = 3 
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The following list describes the classes of operators in order of precedence: 

* Parenthesized expressions 
o NUL 

* HIGH, LOW 

* Multiplication/Division: *, /, MOD, SHL, SHR 
« Addition/Subtraction: +, - (unary and binary) 

Relational Operators: EQ, LT, LE, GT, GE, NE 
«> Logical NOT 

* Logical AND 

* Logical OR, XOR 

The relational, logical, and HIGH/LOW operators must be separated from their operands by at least one blank. 



Relocatable Expressions 

Determining tie repeatability of an expression requires that you understand the repeatability of each term used 
in the express on. This is easier than it sounds since the number of allowable operators is substantially reduced. 
But first it is necessary to know what determines whether a symbol is absolute or relocatable. 

Absolute symbols can be defined two ways: 

9 A symbol that appears in a label field when the ASEG directive is in effect is an absolute symbol. 
e A symbol defined as equivalent to an absolute expression using the SET or EQU directive is an 
absolute symbol. 

Relocatable symbols can be defined a number of ways: 

A symbol that appears in a label field when the DSEG or CSEG directive is in effect is a relocatable 

symbol. 
@ A symbol defined as equivalent to a relocatable expression using the SET or EQU directive is 

relocatable. 
o The special assembler symbols STACK and MEMORY are relocatable, 
o External symbols are considered relocatable. 
& A reference to the location counter (specified by the $ character) is relocatable when the CSEG or 

DSEG directive is in effect. 

The expressions shown in the following list are the only expressions that yield a relocatable result. Assume that 
ABS is an absolute symbol and RELOC is a relocatable symbol: 

ABS + RELOC 
RELOC + ABS 
RELOC - ABS 

/ HIGH \ RELOC + ABS 

\low J 

i'HIGH^ REL0C „ ABS 

\low ) 



( HIGH^ 
t N LOW ) ' 



REL0C + * LOW ; ABS 
( HIGH> 

RELOC ~Uow ) ABS 
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Remember that numbers are absolute terms. Thus the expression RELOC - 100 is legal, but 100 
is not. 



RELOC 



When two relocatable symbols have both been defined with the same type of relocatabiiity, they may appear in 
certain expressions that yield an absolute result. Symbols have the same type of relocatabiiity when both are 
relative to the CSEG location counter, both are relative to the DSEG location counter, both are relative to 
MEMORY, or both are relative to STACK. The following expressions are valid and produce absolute results: 



RELOC1 - RELOC2 



RELOC1 



EQ 
LT 
< LE 
GT 
GE 
NE 



RELOC2 



Relocatable symbols may not appear in expressions with any other operators. 

The following list shows all possible combinations of operators with absolute and relocatable terms. An A in the 
table indicates that the resulting address is absolute; an R indicates a relocatable address; an I indicates an 
illegal combination. Notice that only one term may appear with the last five operators in the list. 



Operator 


X absolute 


X absolute 


X relocatable 


X relocatable 


Y absolute 


Y relocatable 


Y absolute 


Y relocatable 


X + 


Y 


A 


R 


R 


I 


x _ 


Y 


A 


I. 


R 


A 


X * 


Y 


A 


I 




I 


X / 


Y 


A 


I 




i 


X MOD 


Y 


A 


I 




i 


X SHL 


Y 


A 


I 




1 


X SHR 


Y 


A 


I 




1 


X EQ 


Y 


A 


i 




A 


X LT 


Y 


A 


I 




A 


X LE 


Y 


A 


I 




A 


X GT 


Y 


A 


I 




A 


X GE 


Y 


A 


I 




A 


X NE 


Y 


A 


I 




A 


X AND 


Y 


A 


I 




1 


X OR 


Y 


A 


I 




1 


X XOR 


Y 


A 


I 




1 


NOT 


X 


A 


_ 




_ 


HIGH 


X 


A 


_ 


R 


_ 


LOW 


X 


A 


_ 


R 


_ 


unary+ 


X 


A 


__ 


R 


_ 


unary— 


X 


A 


_ 


I 


_ 
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Chaining of Symbol Definitions 

The ISIS-ll 8O80/8085 Macro Assembler is essentially a 2-pass assembler. All symbol table entries must be 
resolvable in iwo passes. Therefore, 

X EQU Y 

Y EQU 1 

is legal, but in the series 

X EQU Y 

Y EQU Z 
Z EQU 1 

the first line s illegal as X cannot be resolved in two passes and remains undefined. 
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HOW TO USE THIS CHAPTER 

This chapter is a dictionary of 8080 and 8085 instructions. The instruction descriptions are fisted alphabetically 
for quick reference. Each description is complete so that you are seldom required to look elsewhere for addition- 
al information. 

This reference format necessarily requires repetitive information, if you are reading this manual to learn about 
the 8080 or the 8085, do not try to read this chapter from ACI (add immediate with Carry) to XTHL (exchange 
top of stack with H and L registers), instead, read the description of the processor and instruction set in 
Chapter 1 and the programming examples in Chapter 6. When you begin to have questions about particular 
instructions, look them up in this chapter. 



TIMING INFORMATION 

The instruction descriptions in this manual do not explicitly state execution timings. This is because the basic 
operating speed of your processor depends on the clock frequency used in your system. 

The 'state' is the basic unit of time measurement for the processor. A state may range from 480 nanoseconds 
(?20 nanoseconds on the 8085) to 2 microseconds, depending on the clock frequency, When you know the 
length of a state in your system, you can determine an instruction's basic execution time by multiplying that 
figure by the number of states required for the instruction. 

Notice that two sets of cycle/state specifications are given for 8085 conditional call and jump instructions. This 
is because the 8085 fetches the third instruction byte only if it is actually needed; i.e., the specified condition 
is satisfied. 

This basic timing factor can be affected by the operating speed of the memory in your system. With a fast 
clock cycle and a slow memory, the processor can outrun the memory, fn this case, the processor must wait 
for the memory to deliver the desired instruction or data. In applications with critical timing requirements, this 
wait can be significant. Refer to the appropriate manufacturer's literature for memory timing data, 
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AC I ADD IMMEDIATE WITH CARRY 

AC! adds the contents of the second instruction byte and the carry bit to the contents of the accumulator and 
stores the result in the accumulator, 

Opcode Operand 

ACI data 

The operand specifies the actual data to be added to the accumulator except, of course, for the carry bit. Data 
may be in the form of a number, an ASCII constant, the label of a previously defined value, or an expression. 
The data may not exceed one byte. 

The assembler's relocation feature treats all external and relocatable symbols as 16-bit addresses. When one of 
these symbols appears in the operand expression of an immediate instruction, it must be preceded by either the 
HIGH or LOW operator to specify which byte of the address is to be used in the evaluation of the expression. 
When neither operator is present, the assembler assumes the LOW operator and issues an error message. 



1 


1 





1 


1 


1 





data 



Cycles: 


2 


States: 


7 


Addressing: 


immediate 


Flags: 


Z.S.P.CY.AC 



Example: 

Assume that the accumulator contains the value 14H and that the carry bit is set to one. The instruction ACI 66 
has the following effect: 

Accumulator - 14H = 00010100 
Immediate data = 42H = 01000010 

Carry = J 

01010111 - 57H 



AD C ADD WITH CARRY 

The ADC insiruction adds one byte of data plus the setting of the carry flag to the contents of the accumulator. 
The result is .tored in the accumulator, ADC then updates the setting of the carry flag to indicate the outcome 
of the operaton. 

The ADC insiruction 's use of the carry bit enables the program to add multi-byte numeric strings. 
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Add Register to Accumulator with Carry 

Opccde Operand 

ADC reg 

The operand must specify one of the registers A through E, H or L. This instruction adds the contents of the 
specified register and the carry bit to the accumulator and stores the result in the accumulator. 



10 1 


s s s 



Cycles: 1 

States: 4 

Addressings: register 

Flags: Z,S,P,CY t AC 

Add Memory to Accumulator with Carry 

Opcode Operand 

ADC M 

This instruction adds the contents of the memory location addressed by the H and L registers and the carry 
bit to the accumulator and stores the resuit in the accumulator. M is a symbolic reference to the H and L 
registers. 



1110 



Cycles: 


2 


States: 


7 


Addressing: 


register indirect 


Flags: 


Z.S.P.CY.AC 



Example: 



Assume that register C contains 3DH, the accumulator contains 42H, and the carry bit is set to zero. The 
instruction ADC C performs the addition as follows: 



3DH = 00111101 
42H = 01000010 

CARRY - 

01111111 =7FH 



The condition flags are set as follows: 



Carry 


= 


Sign 


= 


Zero 


= 


Parity 


= 


Aux. Carry 


= 
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if the carry hit is set to one, the instruction has the following results: 



3DH = 


00111101 


42H = 


01000010 


CARRY = 


1 




10000000 


Carry 


- 


Sign 


= 1 


Zero 


= 


Parity 


= 


Aux. Carry 


- 1 



ADD 



ADD 



The ADD in .traction adds one byte of data to the contents of the accumulator. The result is stored in the 
accumulator Notice that the ADD instruction excludes the carry flag from the addition but sets the flag to 
indicate the outcome of the operation. 

Add Registei to Register 



Opcode 



Operand 



ADD 



reg 



The operand must specify one of the registers A through E, H or L. The instruction adds the contents of the 
specified reg ster to the contents of the accumulator and stores the result in the accumulator. 



10 


s s s 



Cycles: 
States: 
Addressing 
Flags: 



1 

4 

register 

Z,S,P,CY,AC 



Add From Memory 



Opcode 



Operand 



ADD 



M 



This instruciion adds the contents of the memory location addressed by the H and L registers to the contents of 
the accumul itor and stores the result in the accumulator. M is a symbolic reference to the H and L registers. 



10 110 



Cycles: 
States: 
Addressing: 
Flags: 



34 



2 

7 

register indirect 

Z,S,P,CY,AC 
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Examples: 

Assume that the accumulator contains 6CH and register D contains 2EH. The instruction ADD D performs the 
addition as follows: 

2EH = 00101110 
6CH = 01101100 



9AH = 10011010 



The accumulator contains the value 9AH following execution of the ADD D instruction. The contents of the D 
register remain unchanged. The condition flags are set as follows: 



Carry 


= 


Sign 


= i 


Zero 


= 


Parity 


= ] 


Aux. Carry 


= i 



The following instruction doubles the contents of the accumulator: 

ADD A 



ADI 



ADD IMMEDIATE 



ADI adds the contents of the second instruction byte of the contents of the accumulator and stores the result 
in the accumulator. 

Opcode Operand 

ADI data 

The operand specifies the actual data to be added to the accumulator. This data may be in the form of a number, 
an ASCII constant, the label of a previously defined value, or an expression. The data may not exceed one byte. 



The assembler's relocation feature treats all external and relocatable symbols as 16-bit addresses. When one of 
these symbols appears in the operand expression of an immediate instruction, it must be preceded by either 
the HIGH or LOW operator to specify which byte of the address is to be used in the evaluation of the expression. 
When neither operator is present, the assembler assumes the LOW operator and issues an error message. 



110 11 



data 



Cycles: 
States: 
Addressing: 
Flags: 







2 

7 

Immediate 

Z,S,P,CY,AC 
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Example: 

Assume that :he accumulator contains the value 14H. The instruction ADI 66 has the following effect: 

Accumulator = 14H = 00010100 
Immediate data = 42H = 01000010 

01010110 = 56H 

Notice that the assembler converts the decimal value 66 into the hexadecimal value 42. 

ANA LOGICAL AND WITH ACCUMULATOR 

ANA perforrrs a logical AND operation using the contents of the specified byte and the accumulator, The result 
ss placed in the accumulator. 

Summary of Logical Operations 

AND produces a one bit in the result only when the corresponding bits in the test data and the mask data are 
ones. 



OR produces a one bit in the result when the corresponding bits in either the test data or the mask data are 
ones. 

Exclusive OR produces a one bit only when the corresponding bits in the test data and the mask data are 
different; i.e. a one bit in either the test data or the mask data - but not both — produces a one bit in the 
result. 



OR 

1010 1010 
0000 1111 
1010 1111 



Operand 



EXCLUSIVE OR 

1010 1010 
0000 1111 
1010 0101 



AND 

1010 1010 
0000 1111 
0000 1010 

AND Register with Accumulator 

Opcode 

ANA 



The operand must specify one of the registers A through E, H or L. This instruction ANDs the contents of the 
specified register with the accumulator and stores the result in the accumulator. The carry flag is reset to zero. 



10 10 


s s s 



Cycles: 
States: 
Addressing: 

Flags: 



1 

4 

register 

Z t S,P,CY t AC 
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AND Memory with Accumulator 

Opcode Operand 

ANA M 

This instruction ANDs the contents of the specified memory location with the accumulator and stores the result 
in the accumulator. The carry flag is reset to zero. 



10 10 110 



1111 


110 0= 0FCH 





1111= 0FH 





110 0= 0CH 



Cycles: 2 

States: 7 

Addressing: register indirect 

Flags: Z,S,P,CY,AC 

Example: 

Since any bit ANDed with a zero produces a zero and any bit ANDed with a one remains unchanged, AND is 
frequently used to zero particular groups of bits. The following example ensures that the high-order four bits of 

the accumulator are zero, and the low-order four bits are unchanged. Assume that the C register contains 0FH: 

Accumulator = 
C Register = 



ANI AND IMMEDIATE WITH ACCUMULATOR 

AN I performs a logical AND operation using the contents of the second byte of the instruction and the accumu- 
lator. The result is placed in the accumulator. ANI also resets the carry flag to zero. 

Opcode Operand 

ANI data 

The operand must specify the data to be used m the AND operation. This data may be in the form of a number, 
an ASCII constant, the label of some previously defined value, or an expression. The data may not exceed one 

byte. 

The assembler's relocation feature treats all external and relocatable symbols as 16-bit addresses. When one of 
these symbols appears in the operand expression of an immediate instruction, it must be preceded by either the 
HIGH or LOW operator to specify which byte of the address is to be used in the evaluation of the expression. 
When neither operator is present, the assembler assumes the LOW operator and issues an error message. 
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1110 110 



data 



Cycles: 2 

States: 7 

Addressing: immediate 

Flags: Z,S,P,CY,AC 

Summary of Logical Operations 

AND product s a one bit in the result only when the corresponding bits in the test data and the mask data are 
ones. 

OR produces a one bit in the result when the corresponding bits in either the test data or the mask data are 
ones. 

Exclusive OR produces a one bit only when the corresponding bits in the test data and the mask data are 
different; i.e. a one bit in either the test data or the mask data — but not both - produces a one bit in the 
result. 

AND OR EXCLUSIVE OR 

1010 1010 1010 1010 1010 1010 

0000 1111 0000 1111 0000 1111 

0000 1010 1010 1111 1010 0101 

Example: 

The following instruction is used to reset OFF bit six of the byte in the accumulator: 

AN! 10111111B 

Since any bit ANDed with a one remains unchanged and a bit ANDed with a zero is rest to zero, the AN I 
instruction shown above sets bit six OFF and leaves the others unchanged. This technique is useful when a 
program uses individual bits as status flags. 

CALL CALL 

The CALL instruction combines functions of the PUSH and IMP instructions. CALL pushes the contents of the 
program counter (the address of the next sequential instruction) onto the stack and then iumps to the address 
specified in tie CALL instruction. 

Each CALL instruction or one of its variants implies the use of a subsequent RET (return) instruction. When a 
call has no corresponding return, excess addresses are built up in the stack. 
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Opcode 
CALL 



Operand 
address 



The address may be specified as a number, a label, or an expression, (The label is most common.) The assembler 
inverts the high and low address bytes when it assembles the instruction. 



1 


10 11 





1 


low addr 


high addr 



Cycles: 5 

States: 17 (18 on 8085) 

Addressing: immediate/register indirect 

Flags: none 



Example: 



When a given coding sequence is required several times in a program, you can usually conserve memory by coding 
the sequence as a subroutine invoked by the CALL instruction or one of its variants. For example, assume that 
an application drives a six-digit LED display; the display is updated as a result of an operator input or because 
of two different calculations that occur in the program. The coding required to drive the display can be included 
in-line at each of the three points where it is needed, or it can be coded as a subroutine. If the label DISPLY is 
assigned to the first instruction of the display driver, the following CALL instruction is used to invoke the 
display subroutine: 



CALL 



DISPLY 



This CALL instruction pushes the address of the next program instruction onto the stack and then transfers 
control to the DISPLY subroutine. The DISPLY subroutine must execute a return instruction or one of its 
variants to resume normal program flow. The following is a graphic illustration of the effect of CALL and return 
instructions: 



CALL- 



CALL. 



CALL 



DISPLY 




DISPLY- - 



DISPLY 



~^-RET 



Consideration for Using Subroutines 

The larger the code segment to be repeated and the greater the number of repetitions, the greater the potential 
memory savings of using a subroutine. Thus, if the display driver in the previous example requires one hundred 
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bytes, coding it in-line would require three hundred bytes. Coded as a subroutine, it requires one hundred bytes 
plus nine bytas for the three CALL instructions. 

Notice that subroutines require the use of the stack. This requires the application to include random access 
memory for ihe stack, When an application has no other need for random access memory, the system designer 
might elect to avoid the use of subroutines. 



CC 



CALL IF CARRY 



The CC instruction combines functions of the JC and PUSH instructions. CC tests the setting of the carry flag. 
If the flag is set to one, CC pushes the contents of the program counter onto the stack and then jumps to the 
address specified in bytes two and three of the CC instruction. If the flag is reset to zero, program execution 
continues whh the next sequential instruction. 



Opcode 
CC 



Operand 
address 



Although the use of a label is most common, the address may also be specified as a number or expression. 



1 


1 


111 








low addr 


high addr 



Cycles: 3 or 5 (2 or 5 on 8085) 

States: 11 or 17 (9 or 18 on 8085) 

Addressing: immediate/register indirect 

Flags: none 

Example: 

For the sake of brevity, an example is given for the CALL instruction but not for each of its closely related 
variants. 



CM 



CALL IF MINUS 



The CM instruction combines functions of the JM and PUSH instructions. CM tests the setting of the sign flag. 
If the flag is set to one (indicating that the contents of the accumulator are minus), CM pushes the contents 
of the program counter onto the stack and then jumps to the address specified by the CM instruction. If the 
flag is set to zero, program execution simply continues with the next sequential instruction. 



Opcode 



Operand 



CM 



address 
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Although the use of a label is most common, the address may also be specified as a number or an expression. 



1 1 


1111 








low addr 


high addr 



Cycles: 3 or 5 (2 or 5 on 8085) 

States: 1 1 or 17 (9 or 18 on 8085) 

Addressing: immediate/register indirect 

Flags: none 



Example: 



For the sake of brevity, an example is given for the CALL instruction but not for each of its closely related 
variants. 



CMA 



COMPLEMENT ACCUMULATOR 



CMA complements each bit of the accumulator to produce the one's complement. All condition flags remain 
unchanged. 



Opcode 


Operand 


CMA 




Operands are not permitted with the CMA 


instruction. 




1 


1111 




Cycles: 
States: 
Flags: 


1 
4 
none 



To produce the two's complement, add one to the contents of the accumulator after the CMA instructions has 
been executed. 

Example: 

Assume that the accumulator contains the value 51 H; when complemented by CMA, it becomes OAEH: 

51 H = 01010001 
OAEH = 10101110 



3-11 



Chapter 3. instruction S* t 



CMC COMPLEMENT CARRY 

If the carry flag equals zero, CMC sets it to one. if the carry flag is one, CMC resets it to zero. AM other fiags 
remain unchanged. 

Opcode Operand 

CMC 

Operands are not permitted with the CMC instruction. 



11 



1 1 



Cycles: 
States: 
Flags: 



1 
4 
CY only 



Example: 

Assume that a program uses bit 7 of a byte to control whether a subroutine is called. To test the bit, the pro- 
gram loads the byte into the accumulator, rotates bit 7 into the carry flag, and executes a CC (Call if Carry) 
instruction. Before returning to the calling program, the subroutine reinitializes the flag byte using the following 
code: 



CMC 
RAR 
RET 



SET BIT 7 OFF 

ROTATE BIT 7 INTO ACCUMULATOR 

RETURN 



CMP COMPARE WITH ACCUMULATOR 

CMP compares the specified byte with the contents of the accumulator and indicates the result by setting the 
carry and zeio flags. The values being compared remain unchanged. 

The zero flaj indicates equality. No carry indicates that the accumulator is greater than the specified byte; a 
carry indicates that the accumulator is less than the byte. However, the meaning of the carry flag is reversed 
when the values have different signs or one of the values is complemented. 

The program tests the condition fiags using one of the conditional Jump, Call, or Return instructions. For 
example, JZ (Jump if Zero) tests for equality, 

Functional Description: 

Comparisons are performed by subtracting the specified byte from the contents of the accumulator, which 
is why the zero and carry fiags indicate the result. This subtraction uses the processor's internal registers 
so that source data is preserved. Because subtraction uses two's complement addition, the CMP instruction 
recomplements the carry flag generated by the subtraction. 
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Compare Register with Accumulator 

Opcode Operand 

CMP reg 

The operand must name one of the registers A through E, H or L. 





1 


1 


1 


1 


s s s 




Cycles: 
States: 
Address 
Flags: 


ng: 




1 

4 

register 

Z^.P.CY.AC 


Compare Memory with Accumulator 








Opcode 




Operand 


CMP 






M 







This instruction compares the contents of the memory location addressed by the H and L registers with the 
contents of the accumulator. M is a symbolic reference to the H and L register pair. 



10 111110 



Cycles: 
States: 
Addressing: 
Flags: 



2 

7 

register indirect 

Z,S,P,CY,AC 



Example 1: 



Assume that the accumulator contains the value OAH and register E contains the value 05H. The instruction 
CMP E performs the following internal subtraction (remember that subtraction is actually two's complement 
addition): 

Accumulator = 00001010 
+(-E Register) - 11111011 

00000101 +(-carry) 

After the carry is complemented to account for the subtract operation, both the zero and carry bits are zero, 
thus indicating A greater than E. 

Example 2: 

Assume that the accumulator contains the value — 1 BH and register E contains 05H: 

Accumulator = 11100101 
+(-E Register) = 11111011 



11100000 +(-carry) 



3-13 



Chapter 3. Instruction S;t 



After the CMP instruction recompiements the carry flag, both the carry flag and zero flag are zero. Normally 
this indicate -. that the accumulator is greater than register E. However, the meaning of the carry flag is reversed 
since the values have different signs. The user program is responsible for proper interpretation of the carry flag. 



CNC 



CALL IF NO CARRY 



The CNC instruction combines functions of the jNC and PUSH instructions. CNC tests the setting of the carry 
flag. If the fag is set to zero, CNC pushes the contents of the program counter onto the stack and then jumps 
to the address specified by the CNC instruction. If the flag is set to one, program execution simply continues 
with the not sequential instruction. 



Opcode 
CNC 



Operand 

address 



Although th<: use of a label is most common, the address may also be specified as a number or an expression. 



110 10 1 








low addr 


high addr 



Cycles: 3 or 5 (2 or 5 on 8085) 

States: 1 1 or 17 (9 or 18 on 8085) 

Addressing: immediate/register indirect 

Flags: none 



Example: 



For the sake of brevity, an example is given for the CALL instruction but not for each of its closely related 
variants. 



CNZ 



CALL IF NOT ZERO 



The CNZ instruction combines functions of the JNZ and PUSH instructions. CNZ tests the setting of the zero 
flag. If the fag is off (indicating that the contents of the accumulator are other than zero), CNZ pushes the 
contents of :he program counter onto the stack and then jumps to the address specified in the instruction's 
second and ihird bytes. If the flag is set to one, program execution simply continues with the next sequential 
instruction. 

Opcode Operand 

CNZ address 

Although th a use of a label is most common, the address may also be specified as a number or an expression. 
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1 


1 


1 








low addr 


high addr 



Cycles: 3 or 5 (2 or 5 on 8085) 

States: 11 or 17 (9 or 18 on 8085) 

Addressing: immediate/register indirect 

Flags: none 

Example: 

For the sake of brevity, an example is given for the CALL instruction but not for each of its closely related 
variants. 



CP 



CALL IF POSITIVE 



The CP instruction combines features of the JP and PUSH instructions. CP tests the setting of the sign flag. If 
the flag is set to zero (indicating that the contents of the accumulator are positive), CP pushes the contents of 
the program counter onto the stack and then jumps to the address specified by the CP instruction. If the flag 
is set to one, program execution simply continues with the next sequential instruction. 



Opcode 
CP 



Operand 
address 



Although the use of a label is more common, the address may also be specified as a number or an expression. 



1 


1 


110 1 








low address 


high addr 



Cycles: 3 or 5 (2 or 5 on 8085) 

States: 1 1 or 17 (9 or 18 on 8085) 

Addressing: immediate/register indirect 

Flags: none 

Example: 

For the sake of brevity, an example is given for the CALL instruction but not for each of its closely related 
variants. 
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CPE 



CALL IF PARITY EVEN 



Parity is even if the byte in the accumulator has an even number of one bits. The parity flag is set to one to 
indicate this condition. The CPE and CPO instructions are useful for testing the parity of input data. However, 
the IN instruction does not set any of the condition flags. The flags can be set without altering the data by 
adding 00H to the contents of the accumulator. 

The CPE instiuction combines functions of the JPE and PUSH instructions. CPE tests the setting of the parity 
flag. If the flag is set to one, CPE pushes the contents of the program counter onto the stack and then jumps 
to the address specified by the CPE instruction. If the flag is set to zero, program execution simply continues 
with the next sequential instruction. 



Opcode 



Operand 



CPE 



address 



Although the use of a label is more common, the address may also be specified as a number or an expression. 



1 


1 


10 11 








low addr 


high addr 



Cycles: 3 or 5 (2 or 5 on 8085) 

States: ._ 1 1 or 17 (9 or 18 on 8085) 

Addressing: immediate/register indirect 

Flags: none 



Example: 

For the sake :>f brevity, an example is given for the CALL instruction but not for each of its closely related 
variants. 



CPI 



COMPARE IMMEDIATE 



CP! compares the contents of the second instruction byte with the contents of the accumulator and sets the zero 
and carry fla^s to indicate the result. The values being compared remain unchanged. 

The zero flag indicates equality. No carry indicates that the contents of the accumulator are greater than the 
immediate da:a; a carry indicates that the accumulator is less than the immediate data. However, the meaning 
of the carry 1 lag is reversed when the values have different signs or one of the values is complemented. 



Opcode 



Operand 



CPI 



data 
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The operand must specify the data to be compared. This data may be in the form of a number, an ASCII 
constant, the iabei of a previously defined value, or an expression. The data may not exceed one byte. 

The assembler's relocation feature treats alt external and relocatable symbols as 16-bit addresses. When one of 
these symbols appears in the operand expression of an immediate instruction, it must be preceded by either 
the HIGH or LOW operator to specify which byte of the address is to be used in the evaluation of the 
expression. When neither operator is present, the assembler assumes the LOW operator and issues an error 
message. 



1 1 



Cycles: 
States: 

Addressing 
Flags: 



1 



1110 



data 



2 

7 

register indirect 

Z,S,P,CY,AC 



Example: 

The instruction CPI 'C compares the contents of the accumulator to the letter C (43H). 



CPO 



CALL IF PARITY ODD 



Parity is odd if the byte in the accumulator has an odd number of one bits. The parity flag is set to zero to 
indicate this condition. The CPO and CPE instructions are useful for testing the parity of input data. However, 
the IN instruction does not set any of the condition flags. The flags can be set without altering the data by 
adding 00H to the contents of the accumulator, 

The CPO instruction combines functions of the JPOand PUSH instructions. CPO tests the setting of the parity 
flag. If the flag is set to zero, CPO pushes the contents of the program counter onto the stack and then jumps 
to the address specified by the CPO instruction. If the flag is set to one, program execution simply continues 
with the next sequential instruction. 



Opcode 



Operand 



CPO 



address 



Although the use of a label is more common, the address may also be specified as a number or an expression. 



1 


1 


10 1 








low addr 


high addr 



Cycles: 3 or 5 (2 or 5 on 8085) 

States: 11 or 17 (9 or 18 on 8085) 

Addressing: immediate/register indirect 

Flags: none 
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Example: 



For the sake of brevity, an example is given for the CALL instruction but not for each of its closely related 
variants. 



CZ 



CALL IF ZERO 



The CZ instruction combines functions of the JZ and PUSH instructions. CZ tests the setting of the zero fiag. 
If the fiag is set to one (indicating that the contents of the accumulator are zero), CZ pushes the contents of 
the program ;ounter onto the stack and then jumps to the address specified in the CZ instruction. If the fiag 
is set to zero (indicating that the contents of the accumuiator are other than zero), program execution simply 
continues vviih the next sequential instruction. 



Opcode 



Operand 



CZ 



address 



Although the use of a label is most common, the address may also be specified as a number or an expression. 



1 


10 11 








low addr 


high addr 



Cycles: 3 or 5 (2 or 5 on 8085) 

States: 1 1 or 1 7 (9 or 1 8 on 8085) 

Addressing: immediate/register indirect 

Flags: none 



Example: 



For the sake of brevity, an example is given for the CALL instruction but not for each of its closely related 
variants. 



DAA 



DECIMAL ADJUST ACCUMULATOR 



The DAA instruction adjusts the eight-bit value in the accumulator to form two four-bit binary coded decimal 
digits. 



Opcode 
DAA 



Operand 



Operands are not permitted with the DAA instruction. 

DAA is used when adding decimal numbers. It is the only instruction whose function requires use of the auxiliary 
carry flag. In multi-byte arithmetic operations, the DAA instruction typically is coded immediately after the arith- 
metic instruction so that the auxiliary carry flag is not altered unintentionally. 
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DAA operates as follows: 

1. If the least significant four bits of the accumulator have a value greater than nine, or if the auxiliary 
carry flag is ON, DAA adds six to the accumulator, 

2. If the most significant four bits of the accumulator have a value greater than nine, or if the carry 
flag is ON, DAA adds six to the most significant four bits of the accumulator. 



10 111 



Cycles: 1 

States: 4 

Addressing: register 

Flags: Z,S,P,CY,AC 

Example: 

Assume that the accumulator contains the value 9BH as a result of adding 08 to 93: 



CY 


AC 








1001 


0011 


0000 


1000 



1001 1011 = 9BH 
Since 0BH is greater than nine, the instruction adds six to contents of the accumulator: 

CY AC 

1 
1001 1011 
0000 0110 

1010 0001 = A1H 

Now that the most significant bits have a value greater than nine, the instruction adds six to them: 

CY AC 

1 1 
1010 0001 
0110 0000 
0000 0001 

When the DAA has finished, the accumulator contains the value 01 in a BCD format; both the carry and auxiliary 
carry flags are set ON. Since the actual result of this addition is 101, the carry flag is probably significant to the 
program. The program is responsible for recovering and using this information. Notice that the carry flag setting is 
lost as soon as the program executes any subsequent instruction that alters the flag. 
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DAD 



DOUBLE REGISTER ADD 



3-20 



DAD adds the 16-bit value in the specified register pair to the contents of the H and L register pair. The result 
is stored in H and L. 



Opcode 



Operand 



DAD 



DAD may add only the contents of the B&C, D&E, H&L, or the SP (Stack Pointer} register pairs to the contents 
of H&L. No ice that the letter H must be used to specify that the H&L register pair is to be added to itself. 

DAD sets thu carry flag ON if there is a carry out of the H and L registers. DAD affects none of the condition 
flags other than carry. 






R P 


10 1 



Cycles: 
States: 
Addressing: 
Flags: 



3 
10 

register 
CY 



Examples: 

The DAD instruction provides a means for saving the current contents of the stack pointer. 



LXI H t 00H 
DAD SP 
SHLD SAVSP 



CLEAR H&L TO ZEROS 
GET SP INTO H&L 
STORE SP IN MEMORY 



The instruct on DAD H doubles the number in the H and L registers except when the operation causes a carry 
out of the I- register, 



DCR 



DECREMENT 



DCR subtracts one from the contents of the specified byte. DCR affects ail the condition flags except the carry 
flag. Because DCR preserves the carry flag, it can be used within multi-byte arithmetic routines for decrementing 
character co jnts and similar purposes. 

Decrement Register 



Opcode 
DCR 



Operand 
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The operand must specify one of the registers A through E, H or L. The instruction subtracts one from the 
contents of the specified register. 



Decrement Memory 







D D D 



1 1 



Cycles: 


1 


States: 


5 (4 on 8085) 


Addressing: 


register 


Fiags: 


Z,S,P,AC 



Opcode 
DCR 



Operand 
M 



This instruction subtracts one from the contents of the memory location addressed by the H and 
M is a symbolic reference to the H and L registers. 



registers. 



1 



1 



10 1 



Cycles: 
States: 
Addressing: 
Flags: 



3 

10 

register indirect 

Z,S,P,AC 



Example: 

The DCR instruction is frequently used to control multi-byte operations such as moving a number of characters 
from one area of memory to another: 



LOOP: 



MVI 


B,5H 


LXI 


H.260H 


LXI 


D.900H 


MOV 


A,M 


STAX 


D 


DCX 


D 


DCX 


M 


DCR 


B 


JNZ 


LOOP 



SET CONTROL COUNTER 

LOAD H&L WITH SOURCE ADDR 

LOAD D&E WITH DESTINATION ADDR 

LOAD BYTE TO BE MOVED 

STORE BYTE 

DECREMENT DESTINATION ADDRESS 

DECREMENT SOURCE ADDRESS 

DECREMENT CONTROL COUNTER 

REPEAT LOOP UNTIL COUNTERS 



This example also illustrates an efficient programming technique. Notice that the control counter is decremented 
to zero rather than incremented until the desired count is reached. This technique avoids the need for a compare 
instruction and therefore conserves both memory and execution time. 
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DCX 



DECREMENT REGISTER PAIR 



DCX decrements the contents of the specified register pair by one. DCX affects none of the condition flags. 
Because DCX preserves all the flags, it can be used for address modification in any instruction sequence that 
relies on the passing of the flags. 



Opcode 



Operand 



DCX 



DCX may decrement only the B&C, D&E, H&L, or the SP (Stack Pointer) register pairs. Notice that the letter 
H must be used to specify the H and L pair. 



Exercise can- when decrementing the stack pointer as this causes a loss of synchronization between the pointer 
and the actual contents of the stack. 







10 11 



Cycles: 


1 


States: 


5 (6 on 8085) 


Addressing: 


register 


Flags: 


none 



Example: 

Assume that the H and L registers contain the address 9800H when the instruction DCX H is executed. DCX 
considers th<; contents of the two registers to be a single 16-bit value and therefore performs a borrow from the 
H register tc produce the value 97FFH. 



DI 



DISABLE INTERRUPTS 



The interrupt system is disabled when the processor recognizes an interrupt or immediately following execution 
of a DI instiuction. 

In applications that use interrupts, the DI instruction is commonly used oniy when a code sequence must not be 
interrupted. For example, time-dependent code sequences become inaccurate when interrupted. You can disable 
the interrup system by including a DI instruction at the beginning of the code sequence. Because you cannot 
predict the occurrence of an interrupt, include an El instruction at the end of the time-dependent code sequence. 



Opcode 
DI 



Operand 



Operands an not permitted with the DI instruction. 
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11110 1 



Cycles: 
States: 
Flags: 



1 

4 
none 



NOTE 

The 8085 TRAP interrupt cannot be disabled. This special interrupt is 
intended for serious problems that must be serviced regardless of the 
interrupt flag such as power failure or bus error. However, no interrupt 
including TRAP can interrupt the execution of the Dl or El instruction. 



El ENABLE INTERRUPTS 

The El instruction enables the interrupt system following execution of the next program instruction. Enabling 
the interrupt system is delayed one instruction to allow interrupt subroutines to return to the main program 
before a subsequent interrupt is acknowledged. 

In applications that use interrupts, the interrupt system is usually disabled only when the processor accepts an 
interrupt or when a code sequence must not be interrupted. You can disable the interrupt system by including 
a Dl instruction at the beginning of the code sequence. Because you cannot predict the occurrence of an 
interrupt, include an El instruction at the end of the code sequence. 



Opcode 



Operand 



Operands are not permitted with the El instruction. 



11110 11 



Cycles: 
States: 
Flags: 



1 
4 
none 



NOTE 

The 8085 TRAP interrupt cannot be disabled. This special interrupt is 
intended for serious problems that must be serviced regardless of the 
interrupt flag such as power failure or bus failure. However, no interrupt 
including TRAP can interrupt the execution of the Dl or El instruction. 

Example: 

The El instruction is frequently used as part of a start-up sequence. When power is first applied, the processor 
begins operating at some indeterminate address. Application of a RESET signal forces the program counter to 
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zero. A common instruction sequence at this point is El, HLT, These instructions enable the interrupt system 
(RESET also disables the interrupt system) and halt the processor. A subsequent manuai or automatic interrupt 
then determines the effective start-up address. 

HLT HALT 

The HLT induction halts the processor. The program counter contains the address of the next sequential 
instruction. Otherwise, the flags and registers remain unchanged. 



1110 110 



Cycles: 1 

States: 7 (5 on 8085) 

Flags: none 

Once in the halt state, the processor can be restarted only by an external event, typically an interrupt. Therefore, 
you should oe certain that interrupts are enabled before the HLT instruction is executed. See the description of 
the Ei (Ena)le Interrupt) instruction. 

If an 8080 HLT instruction is executed while interrupts are disabled, the only way to restart the processor is 
by application of a RESET signal. This forces the program counter to zero. The same is true of the 8085, except 
for the TRAP interrupt, which is recognized even when the interrupt system is disabled. 

The processor can temporarily leave the halt state to service a direct memory access request. However, the pro- 
cessor reenters the halt state once the request has been serviced. 

A basic purpose for the HLT instruction is to allow the processor to pause while waiting for an interrupt from a 
peripheral device. However, a halt wastes processor resources and should be used only when there is no useful 
processing tisk available. 

IN INPUT FROM PORT 

The IN instruction reads eight bits of data from the specified port and loads it into the accumulator. 

NOTE 

This description is restricted to the exact function of the IN instruction, 
input/output structures are described in the 8080 or 8085 Microcomputer 
Systems User's Manuai. 

Opcode Operand 

IN exp 

The operand expression may be a number or any expression that yields a value in the range 00H through 0FFH. 
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110 110 11 



exp 



Cycles: 
States: 
Addressing: 
Flags: 



3 

10 

direct 
none 



INR INCREMENT 

INR adds one to the contents of the specified byte. !NR affects all of the condition flags except the carry flag. 
Because INR preserves the carry flag, it can be used within multi-byte arithmetic routines for incrementing 
character counts and similar purposes. 

Increment Register 



Opcode 



Operand 



INR 



reg 



The operand must specify one of the registers A through E, H or L The instruction adds one to the contents of 
the specified register. 



D D D 1 



Cycles: 
States: 
Addressing: 
Flags: 



1 

5 (4 on 8085) 

register 

Z,S,P,AC 



Increment Memory 



Opcode Operand 

INR M 



This instruction increments by one the contents of the memory location addressed by the H and L registers, M 
is a symbolic reference to the H and L registers. 



110 10 



Cycles: 


3 


States: 


10 


Addressing: 


register indirect 


Flags: 


Z,S,P,AC 
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Example: 

If register C contains 99H, the instruction INR C increments the contents of the register to 9AH, 



INX INCREMENT REGISTER PAIR 

1NX adds one to the contents of the specified register pair, INX affects none of the condition flags. Because 
INX preserves all the condition flags, it can be used for address modification within multi-byte arithmetic 
routines. 



Opcode 



Operand 



INX 



INX may increment only the B&C, D&E, H&L, or the SP (Stack Pointer) register pairs. Notice that the letter H 
must be used to specify the H and L register pair. 

Exercise care when incrementing the stack pointer, Assume, for example, that INX SP is executed after a number 
of items have been pushed onto the stack. A subsequent POP instruction accesses the high-order byte of the most 
recent stack entry and the low-order byte of the next older entry, Similarly, a PUSH instruction adds the two 
new bytes t3 the stack, but overlays the low-order byte of the most recent entry. 



R 



Cycles: 

States: 

Addressing 

Flags: 



11 



1 

5 {6 on 8085) 

register 

none 



Example: 

Assume tha. the D and E registers contain the value 01FFH. The instruction INX D increments the value to 
0200H. By :ontrast, the INR E instruction ignores the carry out of the low-order byte and produces a result of 
0100H. (This condition can be detected by testing the Zero condition flag.) 

If the stack pointer register contains the value OFFFFH, the instruction INX SP increments the contents of SP 
to 0000H. "he INX instruction sets no flags to indicate this condition. 



JC JUMP IF CARRY 

The JC instruction tests the setting of the carry flag. If the flag is set to one, program execution resumes at the 
address specified in the JC instruction. If the flag is reset to zero, execution continues with the next sequential 
instruction. 
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Opcode 



Operand 
address 



The address may be specified as a number, a label, or an expression. The assembler inverts the high and low 
address bytes when it assembles the instruction. 



1 


1 


110 


1 





low addr 


high addr 



Cycles: 
States: 
Addressing: 
Flags: 



3 (2 or 3 on 8085) 
10 (7 or 10 on 8085) 
immediate 



Example: 

Examples of the variations of the jump instruction appear in the description of the JPO instruction. 



JM JUMP IF MINUS 

The JM instruction tests the setting of the sign flag. If the contents of the accumulator are negative (sign flag = 1), 
program execution resumes at the address specified in the JM instruction. If the contents of the accumulator are 
positive (sign flag = 0), execution continues with the next sequential instruction. 



Opcode 



Operand 



address 



The address may be specified as a number, a label, or an expression. The assembler inverts the high and low 
address bytes when it assembles the instructions. 



1 


1 


1110 


1 





low addr 


high addr 



Cycles: 
States: 
Addressing: 
Flags: 



3 (2 or 3 on 8085) 
10 (7 or 10 on 8085) 
immediate 



Example: 

Examples of the variations of the lump instruction appear in the description of the JPO instruction. 
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JMP 



JUMP 

The JMP instruction alters the execution sequence by loading the address in its second and third bytes into the 
program counter. 



Opcode 
JMP 



Operand 
address 



The address nay be specified as a number, a label, or an expression. The assembler inverts the high and low 
address bytes when it assembles the address. 



1 


1 





1 


1 


low addr 


high addr 



Cycles: 


3 


States: 


10 


Addressing: 


immediate 


Flags: 


none 



Example: 

Examples of the variations of the jump instruction appear in the description of the JPO instruction. 



JNC 



JUMP IF NO CARRY 

The JNC insi ruction tests the setting of the carry flag. If there is no carry (carry flag = 0), program execution 
resumes at the address specified in the JNC instruction. If there is a carry (carry flag = 1), execution continues 
with the next sequential instruction. 



Opcode 



Operand 



JNC 



address 



The address nay be specified as a number, a label, or an expression. The assembler inverts the high and low 
address byte . when it assembles the instruction. 



1 


1 





1 


1 





low addr 


high addr 



Cycles: 


3 (2 or 3 on 8085) 


States: 


10 (7 or 10 on 8085) 


Addressing: 


immediate 


Flags: 


none 
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JNZ 



JP 



Example: 

Exampies of the variations of the jump instruction appear in the description of the JPO instruction. 



JUMP IF NOT ZERO 

The JNZ instruction tests the setting of the zero flag. If the contents of the accumulator are not zero (zero 
flag = 0), program execution resumes at the address specified in the JNZ instruction. If the contents of the 
accumulator are zero (zero flag = 1), execution continues with the next sequential instruction. 



Opcode 



JNZ 



Operand 



address 



The address may be specified as a number, a label, or an expression. The assembler inverts the high and low 
address bytes when it assembles the instruction. 



1 


10 


1 





low addr 


high addr 



Cycles: 3 (2 or 3 on 8085) 

States: 10 (7 or 10 on 8085} 

Addressing: immediate 

Flags: none 

Example: 

Examples of the variations of the jump instruction appear in the description of the ]PO instruction. 



JUMP IF POSITIVE 

The JP instruction tests the setting of the sign flag. If the contents of the accumulator are positive (sign flag = 0), 
program execution resumes at the address specified in the JP instruction. If the contents of the accumulator are 
minus (sign flag = 1), execution continues with the next sequential instruction. 



Opcode 
IP 



Operand 
address 



The address may be specified as a number, a label, or an expression. The assembler inverts the high and low order 
address bytes when it assembles the instruction. 
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!PE 



1 1 


110 


1 





low addr 


high addr 



Cycles: 3 (2 or 3 on 8085) 

States: 10 (7 or 10 on 8085) 

Addressing: immediate 

FSags: none 

Example: 

Examples of the variations of the jump instruction appear In the description of the JPO instruction. 



JUMP IF PARITY EVEN 

Parity is even if the byte in the accumulator has an even number of one bits. The parity flag is set to one to 
indicate this condition. 

The JPE instruction tests the setting of the parity flag. If the parity flag is set to one, program execution resumes 
at the address specified in the JPE instruction. If the flag is reset to zero, execution continues with the next 
sequential instruction. 



Opcode 
JPE 



Operand 
address 



The address may be specified as a number, a label, or an expression. The assembler inverts the high and low 
address byte, when it assembles the instruction. 

The JPE anc JPO (jump if parity odd) instructions are especially useful for testing the parity of input data. 
However, th<; IN instruction does not set any of the condition flags. The flags can be set by adding 00H to the 
contents of tie accumulator, 



1 1 1 


1 


1 





low addr 


high addr 



Cycles: 
States: 
Addressing: 
Flags: 



3 (2 or 3 on 8085) 
10 (7 or 10 on 8085) 
immediate 

none 



Example: 

Examples ol the variations of the jump instruction appear in the description of the JPO instruction. 
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JPO 



JUMP IF PARITY ODD 



Parity is odd if the byte in the accumulator has an odd number of one bits. The parity flag is set to zero to 
indicate this condition. 

The JPO instruction tests the setting of the parity flag. If the parity flag is reset to zero, program execution 
resumes at the address specified in the JPO instruction. If the flag is set to one, execution continues with the 
next sequential instruction. 



Opcode 



Operand 



IPO 



address 



The address may be specified as a number, a label, or an expression. The assembler inverts the high and low 
address bytes when it assembles the instruction. 

The JPO and JPE (jump if parity even) instructions are especially useful for testing the parity of input data. 
However, the IN instruction does not set any of the condition flags. The flags can be set by adding 00H to the 
contents of the accumulator. 



1 


1 


10 


1 





low addr 


high addr 



Cycles: 


3 (2 or 3 on 8085) 


States: 


10 (7 or 10 on 8085) 


Addressing: 


immediate 


Flags: 


none 



Example: 

This example shows three different but equivalent methods for jumping to one of two points in a program based 
upon whether or not the Sign bit of a number is set. Assume that the byte to be tested is the C register. 



Label 


Code 


Operand 


ONE: 


MOV 


A.C 




AN I 


80H 




JZ 


PLUS 




JNZ 


MINUS 


TWO: 


MOV 
RLC 


A.C 




JNC 


PLUS 




JMP 


MINUS 


THREE: 


MOV 


A.C 




ADI 







JM 


MINUS 


PLUS: 


- 


;SIGN BIT RESET 


MINUS: 


_ 


:SIGN BIT SET 



3-31 



Chapter 3. Instruction Set 



The AND immediate instruction in block ONE zeroes ail bits of the data byte except the Sign bit, which re- 
mains unchanged. If the Sign bit was zero, the Zero condition bit will be set, and the JZ instruction will cause 
program control to be transferred to the instruction at PLUS. Otherwise, the JZ instruction will merely update 
the program counter by three, and the ]NZ instruction will be executed, causing control to be transferred to 
the instruction at MINUS. (The Zero bit is unaffected by ail jump instructions.) 

The RLC instruction in block TWO causes the Carry bit to be set equal to the Sign bit of the data byte, if the 
Sign bit wa; reset, the JNC instruction causes a jump to PLUS. Otherwise the jMP instruction is executed, 
unconditionally transferring control to MINUS. (Note that, in this instance, a JC instruction could be sub- 
stituted for the unconditional jump with identical results.) 

The add immediate instruction in block THREE causes the condition bits to be set. If the sign bit was set the 
JM instruction causes program control to be transferred to MINUS. Otherwise, program control flows auto- 
matically ir to the PLUS routine. 



j Z JUMP IF ZERO 

The JZ insiruction tests the setting of the zero flag. If the flag is set to one, program execution resumes at the 
address specified in the jZ instruction. If the flag is reset to zero, execution continues with the next sequential 
instruction. 



Opcode 
IZ 



Operand 
address 



The addres, may be specified as a number, a label, or an expression. The assembler inverts the high and low 
address byies when it assembles the instruction. 



1 


10 10 


1 





low addr 


high addr 



Cycles: 
States: 
Addressing: 
Flags: 



3 (2 or 3 on 8085) 
10 (7 or 10 on 8085) 
immediate 
none 



Example: 

Examples of the variations of the jump instruction appear in the description of the jPO instruction. 



LDA 



LOAD ACCUMULATOR DIRECT 



LDA load^ the accumulator with a copy of the byte at the location specified in bytes two and three of the 
LDA instr jction. 
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Opcode 
LDA 



Operand 
address 



The address may be stated as a number, a previously defined label, or an expression. The assembler inverts the 
high and low address bytes when it builds the instruction. 









1110 


1 





low addr 


high addr 



Cycles: 
States: 
Addressing: 
Flags: 



4 
13 

direct 
none 



Examples: 

The following instructions are equivalent. When executed, each replaces the accumulator contents with the byte 
of data stored at memory location 300H. 

LOAD: LDA 300H 

LDA 3*(16*16) 
LDA 200H+256 



LDAX 



LOAD ACCUMULATOR INDIRECT 



L DAX loads the accumulator with a copy of the byte stored at the memory location addressed by register pair 
B or register pair D, 



Opcode 



LDAX 



Operand 



D 



> 



The operand B specifies the B and C register pair; D specifies the D and E register pair. This instruction may 
specify only the B or D register pair. 






r 


10 10 



JO = register pair 8 
|1 = register pair D 



Cycles: 2 

States: 7 

Addressing: register indirect 

Flags: none 
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Example: 



Assume that register D contains 93H and register E contains 8BH. The following instruction loads the accumulator 
with the contents of memory location 9388H: 

LDAX D 



LHLD 



LOAD H AND L DIRECT 

LHLD loads the L register with a copy of the byte stored at the memory location specified in bytes two and 
three of the LHLD instruction. LHLD then loads the H register with a copy of the byte stored at the next 
higher memory location. 



Opcode 



Operand 



LHLD 



address 



The address may be stated as a number, a label, or an expression. 

Certain instructions use the symbolic reference M to access the memory location currently specified by the H and 
L registers. -HLD is one of the instructions provided for loading new addresses into the H and L registers. The 
user may alio load the current top of the stack into the H and L registers (POP instruction). Both LHLD and 
POP replace the contents of the H and L registers. You can also exchange the contents of H and L with the D 
and E registars (XCHG instruction) or the top of the stack (XTHL instruction) if you need to save the current 
H and L registers for subsequent use. SHLD stores H and L in memory. 









1 


1 


1 





low addr 


high addr 



Cycles: 
States: 
Addressing: 
Flags: 



5 

16 

direct 
none 



Example: 

Assume that locations 3000 and 3001 H. contain the address 064EH stored in the format 4E06. In the following 
sequence, the MOV instruction moves a copy of the byte stored at address 064E into the accumulator: 



LHLD 3000H 

MOV A,M 



;5ET UP ADDRESS 

;LOAD ACCUM FROM ADDRESS 
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LXI 



LOAD REGISTER PAIR IMMEDIATE 



LXI is a three-byte instruction; its second and third bytes contain the source data to be loaded into a register 
pair. LXI loads a register pair by copying its second and third bytes into the specified destination register pair. 



Opcode 



LXi 



Operand 



8 
D 
H 
SP 



.data 



The first operand must specify the register pair to be loaded. LXI can load the B and C register pair, the D and 
E register pair, the H and L register pair, or the Stack Pointer, 

The second operand specifies the two bytes of data to be loaded. This data may be coded in the form of a num- 
ber, an ASCII constant, the label of some previously defined value, or an expression. The data must not exceed 
two bytes. 

LXI is the only immediate instruction that accepts a 16-bit value. Ail other immediate instructions require 8-bit 
values. 



Notice that the assembler inverts the two bytes of data to create the format of an address stored in memory. 
LXI loads its third byte into the first register of the pair and its second byte into the second register of the 
pair. This has the effect of reinverting the data into the format required for an address stored in registers. Thus, 
the instruction LXI B.'AZ' loads A into register B and Z into register C. 









R P 








1 


low-order data 


high-order data 



Cycles: 
States: 
Addressing: 
Flags: 



3 

10 

immediate 

none 



Examples: 

A common use for LXI is to establish a memory address for use in subsequent instructions. In the following 
sequence, the LXI instruction loads the address of STRNG into the H and L registers. The MOV instruction then 
loads the data stored at that address into the accumulator, 

LXI H.STRNG ;SET ADDRESS 

MOV A,M ;LOAD STRNG INTO ACCUMULATOR 

The following LXI instruction is used to initialize the stack pointer in a relocatable module. The LOCATE pro- 
gram provides an address for the special reserved label STACK. 



LXI SP.STACK 
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MOV 



MOVE 

The MOV instruction moves one byte of data by copying the source field into the destination field. Source data 
remains unchanged. The instruction's operands specify whether the move is from register to register, from a 
register to memory , or from memory to a register. 



Move Register to Register 



Opcode 



Operand 



MOV 



reg! ,reg2 



The instruction copies the contents of reg2 into regl . Each operand must specify one of the registers A, B, C, D, 
E. H, or L. 

When the same register is specified for both operands (as in MOV A,A), the MOV functions as a NOP (no opera- 
tion) since it has no other noticeable effect. This form of MOV requires one more machine state than NOP, and 
therefore ha; a slightly longer execution time than NOP, Since M addresses a register pair rather than a byte of 
data, MOV M,M is not allowed. 





ID 


D 


D 


S S 5 




Cycles: 




1 




States: 




5 (4 on 8085) 




Addressing: 




register 




Flags: 




none 


Move to Memory 











Opcode 



Operand 



MOV 



M,r 



This instruciion copies the contents of the specified register into the memory location addressed by the H and L 
registers. M s a symbolic reference to the H and L register pair. The second operand must address one of the 
registers. 



1110 


S S s 



Cycles: 
States: 
Addressing: 
Flags: 



2 

7 

register indirect 

none 



Move from Memory 



Opcode 
MOV 



Operand 
r,M 
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This instruction copies the contents of the memory location addressed by the H and L registers into the specified 
register. The first operand must name the destination register. The second operand must be M. M is a symbolic 
reference to the H and L registers. 



1 



D D D 



Cycles: 
States: 
Addressing: 
Flags: 



1 1 



2 

7 

register indirect 

none 



Examples: 



Label Opcode Operands Comment 

LDACC: MOV A,M ;LOAD ACCUM FROM MEMORY 

MOV E,A :COPY ACCUM INTO E REG 

NULOP: MOV C,C ;NULL OPERATION 



MVI 



MOVE IMMEDIATE 



MVI is a two-byte instruction; its second byte contains the source data to be moved. MVI moves one byte of 
data by copying its second byte into the destination field. The instruction's operands specify whether the move 
is to a register or to memory. 

Move Immediate to Register 



Opcode 
MVI 



Operand 
reg,data 



The first operand must name one of the registers A through E, H or L as a destination for the move. 

The second operand specifies the actual data to be moved. This data may be in the form of a number, an ASCII 
constant, the label of some previously defined value, or an expression. The data must not exceed one byte. 



The assembler's relocation feature treats all external and relocatable symbols as 16-bit addresses. When one of 
these symbols appears in the operand expression of an immediate instruction, it must be preceded by either the 
HIGH or LOW operator to specify which byte of the address is to be used in the evaluation of the expression. 
When neither operator is present, the assembler assumes the LOW operator and issues an error message. 






D 


D 


D 


1 1 





data 


Cycles: 






2 




States: 






7 




Address 


ng: 




immediate 




Flags: 






no 


ne 
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Move immediate to Memory 

Opcode Operand 

MVI M.data 

This instruction copies the data stored in its second byte into the memory location addressed by H and L. M is 
a symbolic reference to the H and L register pair. 






" 


1 


1 


1 





data 



Cycles: 


3 


States: 


10 


Addressing: 


immediate/register indirect 


Flags: 


none 



Examples: 

The following examples show a number of methods for defining immediate data in the MVI instruction. All of 
the examples generate the bit pattern for the ASCI! character A, 

MVI M.01000001B 

MVI M,\A' 

MVI M.41H 

MVI M.101Q 

MVI M,65 

MVI M,5+30*2 



NOP NO OPERATION 

NOP perforns no operation and affects none of the condition flags. NOP is useful as filler in a timing loop. 

Opcode Operand 

NOP 
Operands aie not permitted with the NOP instruction. 

ORA INCLUSIVE OR WITH ACCUMULATOR 

ORA perfosms an inclusive OR logical operation using the contents of the specified byte and the accumulator. The 
result is placed in the accumulator, 
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Summary of Logical Operations 

AND produces a one bit in the result only when the corresponding bits in the test data and the mask data are 
one. 

OR produces a one bit in the result when the corresponding bits in either the test data or the mask data are 



Exclusive OR produces a one bit only when the corresponding bits in the test data and the mask data are 
different; i.e., a one bit in either the test data or the mask data - but not both - produces a one bit in the 
result. 



AND 


OR 


EXCLUSIVE OR 


1010 1010 


1010 1010 


1010 1010 


0000 1111 


0000 1111 


0000 1111 


0000 1010 


1010 1111 


1010 0101 


Register with Accumulator 






Opcode 


Operand 




ORA 


reg 





The operand must specify one of the registers A through E, H or L. This instruction ORs the contents of the 
specified register and the accumulator and stores the result in the accumulator. The carry and auxiliary carry 
flags are reset to zero. 





1 1 


1 o 


S s s 




Cycles: 


1 


States: 


4 


Addressing: 


register 


Flags: 


Z.S.P.CY.AC 


OR Memory with Accumulator 




Opcode 


Operand 


ORA 


^ 


M 





The contents of the memory location specified by the H and L registers are inclusive-ORed with the contents of 
the accumulator. The result is stored in the accumulator. The carry and auxiliary carry flags are reset to zero. 



10 110 1 



1 



Cycles: 
States: 
Addressing: 
Flags: 



2 

7 

register indirect 

Z,S,P,CY,AC 
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Example: 



Since any tit inclusive-ORed with a one produces a one and any bit ORed with a zero remains unchanged, ORA 
is frequently used to set ON particular bits or groups of bits. The following example ensures that bit 3 of the 
accumulator is set ON, but the remaining bits are not disturbed. This is frequently done when individual bits 
are used as status flags in a program. Assume that register D contains the value 08H: 

Accumulator =01000011 

Register D = 1 

10 10 11 



ORi INCLUSIVE OR IMMEDIATE 

ORI performs an inclusive OR logical operation using the contents of the second byte of the instruction and the 
contents oi the accumulator, The result is placed in the accumulator. ORI also resets the carry and auxiliary 
carry flags to zero. 

Opcode Operand 

ORI data 

The operard must specify the data to be used in the inclusive OR operation. This data may be in the form of a 
number, ar ASCII constant, the label of some previously defined value, or an expression. The data may not 
exceed one byte. 

The assembler's relocation feature treats all external and relocatable symbols as 16-bit addresses. When one of 
these symbols appears in the operand expression of an immediate instruction, it must be preceded by either the 
HIGH or LOW operator to specify which byte of the address is to be used in the evaluation of the expression. 
When neitter operator is present, the assembler assume the LOW operator and issues an error message. 



11110 110 



data 



Cycles: 2 

States: 7 

Addressing: immediate 

Flags: Z,S,P,SY,AC 

Summary < tf Logical Operations 

AND prod jces a one bit in the result only when the corresponding bits in both the test data and the mask data 
are ones. 

OR produtes a one bit in the result when the corresponding bits in either the test data or the mask data are ones. 

Exclusive OR produces a one bit only when the corresponding bits in the test data and the mask data are 
different; i.e., a one bit in either the test data or the mask data - but not both — produces a one bit in the 
result. 
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AND 



OR 



EXCLUSIVE OR 



1010 1010 
0000 1111 
0000 1010 



1010 1010 
0000 1111 
1010 1111 



1010 1010 
0000 1111 
1010 0101 



Example: 

See the description of the ORA instruction for an example of the use of the inclusive OR. The following 
examples show a number of methods for defining immediate data in the ORI instruction. All of the examples 
generate the bit pattern for the ASCII character A. 



ORI 


01 000001 B 


ORI 


'A s 


OR! 


41 H 


ORI 


101Q 


ORI 


65 


ORI 


5+30*2 



OUT 



OUTPUT TO PORT 



The OUT instruction places the contents of the accumulator on the eight-bit data bus and the number of the 
selected port on the sixteen-bit address bus. Since the number of ports ranges from through 255, the port 
number is duplicated on the address bus. 

It is the responsibility of external logic to decode the port number and to accept the output data. 



NOTE 

Because a discussion of input/output structures is beyond the scope of 
this manual, this description is restricted to the exact function of the 
OUT instruction. Input/output structures are described in the 8080 or 
8085 Microcomputer Systems Users Manual, 



Opcode 



Operand 



OUT 



exp 



The operand must specify the number of the desired output port. This may be in the form of a number or an 
expression in the range 00H through 0FFH. 



110 10 1 



exp 



Cycles: 
States: 
Addressing: 
Flags: 



3 

10 

direct 
none 



1 
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PCHL MOVE H&L TO PROGRAM COUNTER 

PCHL loads tne contents of the H and L registers into the program counter register, Because the processor 
fetches the n<;xt instruction from the updated program counter address, PCHL has the effect of a jump instruc- 
tion. 

Opcode Operand 

PCHL 

Operands are not permitted with the PCHL instruction. 

PCHL moves the contents of the H register to the high-order eight bits of the program counter and the contents 
of the L register to the low-order eight bits of the program counter. 

The user program must ensure that the H and L registers contain the address of an executable instruction when 
the PCHL in:truction is executed. 



1110 10 1 



Cycles: 

States: 

Addressing: 

Bags: 



1 

5 (6 on 8085) 

register 

none 



Example: 

One technique for passing data to a subroutine is to place the data immediately after the subroutine call. The 
return address pushed onto the stack by the CALL instruction actually addresses the data rather than the next 
instruction a ter the CALL. For this example, assume that two bytes of data follow the subroutine call. The 
following coding sequence performs a return to the next instruction after the call: 



GOBACK: 



POP H 

INR L 

INR L 
PCHL 



;GET DATA ADDRESS 
ADD 2 TO FORM 
RETURN ADDRESS 
RETURN 



POP 



POP 



The POP inscruction removes two bytes of data from the stack and copies them to a register pair or copies the 
Program Status Word into the accumulator and the condition flags. 

POP Register Pair 

POP copies ihe contents of the memory location addressed by the stack pointer into the low-order register of the 
register pair POP then increments the stack pointer by one and copies the contents of the resulting address into 
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the high-order register of the pair. POP then increments the stack pointer again so that it addresses the next 
older item on the stack. 



Opcode 



Operand 



POP 



D 
H 
PSW 



The operand may specify the B&C, D&E, or the H&L register pairs. POP PSW is explained separately, 



1 i 



R 



Cycles: 
States: 
Addressing: 
Flags: 



1 



3 

10 

register indirect 

none 



POP PSW 

POP PSW uses the contents of the memory location specified by the stack pointer to restore the condition flags. 
POP PSW increments the stack pointer by one and restores the contents of that address to the accumulator. 
POP then increments the stack pointer again so that it addresses the next older item on the stack. 



1 1 



1 



Cycles: 


3 


States: 


10 


Addressing: 


register indirect 


Flags: 


Z,S,P,CY,AC 



Example: 

Assume that a subroutine is called because of an external interrupt. !n general, such subroutines should save and 
restore any registers it uses so that main program can continue normally when it regains control. The following 
sequence of PUSH and POP instructions save and restore the Program Status Word and ail the registers: 
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PUSH 
PUSH 
PUSH 
PUSH 



PSW 
8 
D 
H 



subroutine coding 



POP 
POP 
POP 
POP 

RET 



H 
D 

B 
PSW 



Notice that the sequence of the POP instructions is the opposite of the PUSH instruction sequence. 



PUSH 



PUSH 



The PUSH instruction copies two bytes of data to the stack. This data may be the contents of a register pair or 
the Program Status Word, as explained below: 

PUSH Regis "er Pair 

PUSH decrements the stack pointer register by one and copies the contents of the high-order register of the 
register pair to the resulting address. PUSH then decrements the pointer again and copies the low-order register 
to the resuhing address. The source registers remain unchanged. 



Opcode 



Operand 



PUSH 



IB 

Id 

|H 
I PSW 



The operand may specify the B&C, D&E, or H&L register pairs. PUSH PSW is explained separately. 



1 1 R P 1 1 



Cycles: 


3 


States: 


11 (13 on 8085} 


Addressing: 


register indirect 


Flags: 


none 



Example: 

Assume tha: register B contains 2AH, the C register contains 4CH, and the stack pointer is set at 9AAF. The 
instruction PUSH B stores the B register at memory address 9AAEH and the C register at 9AADH. The stack 
pointer is set to 9AADH: 
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Stack 
Before PUSH 



Address 



Stack 
After PUSH 



SP before - 



-*- xx 

XX 
XX 
XX 



9AAF 
9AAE 
9AAD 
9AAC 



XX 

2A 

4C -«- 

xx 



■ SP after 



PUSH PSW 

PUSH PSW copies the Program Status Word onto the stack. The Program Status Word comprises the contents 
of the accumulator and the current settings of the condition flags. Because there are only five condition flags, 
PUSH PSW formats the flags into an eight-bit byte as follows: 



7 


6 


5 


4 


3 


2 


1 





1 S 


Z 





AC 


o 


P 


1 


CY 1 



On the 8080, bits 3 and 5 are always zero; bit one is always set to one. These filler bits are undefined on the 
8085. 

PUSH PSW decrements the stack pointer by one and copies the contents of the accumulator to the resulting 
address. PUSH PSW again decrements the pointer and copies the formatted condition flag byte to the resulting 
address. The contents of the accumulator and the condition flags remain unchanged. 



11110 10 1 



Cycles: 


3 


States: 


11 (12 on 8085) 


Addressing: 


register indirect 


Flags: 


none 



Example: 

When a program calls subroutines, it is frequently necessary to preserve the current program status so the calling 
program can continue normally when it regains control. Typically, the subroutine performs a PUSH PSW prior to 
execution of any instruction that might alter the contents of the accumulator or the condition flag settings. 
The subroutine then restores the pre-call system status by executing a POP PSW instruction just before returning 
control to the calling program. 



RAL ROTATE LEFT THROUGH CARRY 

RAL rotates the contents of the accumulator and the carry flag one bit position to the left. The carry flag, which 
is treated as though it were part of the accumulator, transfers to the low-order bit of the accumulator. The high- 
order bit of the accumulator transfers into the carry flag. 



Opcode 



Operand 



RAL 



Operands are not permitted with the RAL instruction. 
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10 111 



Cycles: 
States: 
Flags: 



1 
4 
CY only 



Example: 



Assume that the accumulator contains the value OAAH and the carry flag is zero. The following diagrams illus- 
trate the effect of the RAL instruction: 



Before : 



Carry 

-0- 



Accumulator 



1 10 1 1 



After: 



Carry 

m 

Accumulator 



10 10 10 



RAR ROTATE RIGHT THROUGH CARRY 

RAR rotates the contents of the accumulator and the carry flag one bit position to the right. The carry flag, 
which is treated as though it were part of the accumulator, transfers to the high-order bit of the accumulator. 
The low-ordor bit of the accumulator transfers into the carry flag. 



Opcode 
RAR 



Operand 



Operands arc not permitted with the RAR instruction. 



11111 



Cycles: 


1 


States: 


4 


Flags: 


CY only 
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Example: 

Assume that the accumulator contains the value OAAH and the carry flag is zero. The following diagrams illus- 
trate the effect of the RAR instruction: 



Before: 



Carry 



Accumulator 



10 10 10 10 



After: 



Carry 



Accumulator 



10 10 10 1 



RC 



RETURN IF CARRY 



The RC instruction tests the carry flag, if the flag is set to one to indicate a carry, the instruction pops two 
bytes off the stack and places them in the program counter. Program execution resumes at the new address in 
the program counter, if the flag is zero, program execution simply continues with the next sequential instruction. 



Opcode 
RC 



Operand 



Operands are not permitted with the RC instruction. 



110 110 



Cycles: 1 or 3 

States: 5 or 1 1 (6 or 12 on 8085) 

Addressing: register indirect 

Flags: none 

Example: 

For the sake of brevity, an example is given for the RET instruction but not for each of its closely related 
variants. 
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RET RETURN FROM SUBROUTINE 

The RET instruction pops two bytes of data off the stack and places them in the program counter register. 
Program execution resumes at the new address in the program counter. 

Typically, RET instructions are used in conjunction with CALL instructions. (The same is true of the variants 
of these instructions.) In this case, it is assumed that the data the RET instruction pops off the stack is a 
return address placed there by a previous CALL. This has the effect of returning control to the next instruction 
after the CALL. The user must be certain that the RET instruction finds the address of executable code on the 
stack. If th>: instruction finds the address of data, the processor attempts to execute the data as though it were 
code. 



Opcode 
RET 



Operand 



Operands a~e not permitted with the RET instruction. 



110 10 1 



Cycles: 3 

States: 10 

Addressing: register indirect 

Flags: none 



Example: 



As mentiored previously, subroutines can be nested. That is, a subroutine can call a subroutine that calls 
another subroutine. The only practical limit on the number of nested calls is the amount of memory available 
for stacking return addresses. A nested subroutine can even call the subroutine that called it, as shown in the 
following example. (Notice that the program must contain logic that eventually returns control to the main 
program. Otherwise, the two subroutines will call each other indefinitely.) 



MAIN PROGRAM 



Call suba- 



. SUBA: 



SUBB: 



CNZ SUBB' 



RET' 



'-CALL SUBA 



RET 



RIM (8085 PROCESSOR ONLY) 



READ INTERRUPT MASK 



The RIM instruction loads eight bits of data into the accumulator. The resulting bit pattern indicates the current 
setting of he interrupt mask, the setting of the interrupt flag, pending interrupts, and one bit of serial input data, 
if any. 



3-48 



Chapter 3. Instruction Set 



Opcode Operand 

RiM 
Operands are not permitted with the RIM instruction. 
The RIM instruction loads the accumulator with the following information: 



7 


6 


5 


4 


3 


2 


1 





SID 


17 


16 


15 


IE 


7.5 


6.5 


5.5 



V 



v 

1 — Interrupt Masks: 1 = masked 
-Interrupt Enable Flag: 1 - enabled 



-Pending Interrupts: 1 = pending 



-Serial Input Data Bit, if any 



The mask and pending flags refer only to the RST5.5, RST6.5, and RST7.5 hardware interrupts. The IE flag 
refers to the entire interrupt system. Thus, the IE flag is identical in function and level to the INTE pin on the 
8080. A 1 bit in this flag indicates that the entire interrupt system is enabled. 



1 



Cycles: 
States: 
Flags: 



1 

4 
none 



RLC ROTATE ACCUMULATOR LEFT 

RLC sets the carry flag equal to the high-order bit of the accumulator, thus overwriting its previous setting. RLC 
then rotates the contents of the accumulator one bit position to the left with the high-order bit transferring to 
the low-order position of the accumulator. 



Opcode 
RLC 



Operand 



Operands are not allowed with the RLC instruction. 



111 



Cycles: 
States: 
Flags: 



1 
4 
CY only 
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Example: 



Assume that tie accumulator contains the value OAAH and the carry flag is zero. The following diagrams illus- 
trate the effect of the RLC instruction. 



Before: 



After: 



Carry 



Accumulator 



Carry 
1 
Accumulator 



1 " 





1 





1 





-*J — 

















10 10 10 1 



RM 



RETURN IF MINUS 

The RM instrjction tests the sign flag. If the flag is set to one to indicate negative data in the accumulator, the 
instruction pc ps two bytes off the stack and places them in the program counter, Program execution resumes at 
the new address in the program counter. If the flag is set to zero, program execution simply continues with the 
next sequentui instruction. 



Opcode 



Operand 



RM 



Operands are not permitted with the RM instruction. 



1111 







Cycles: 


1 or 3 


States: 


5 or 11 (6 or 12 on 8085) 


Addressing: 


register indirect 


Flags: 


none 



Example: 

For the sake of brevity, an example is given for the RET instruction but not for each of its closely related 
variants. 
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RNC 



RETURN IF NO CARRY 



The RNC instruction tests the carry flag. !f the flag is set to zero to indicate that there has been no carry, the 
instruction pops two bytes off the stack and places them in the program counter. Program execution resumes at 
the new address in the program counter, if the flag is one, program execution simply continues with the next 
sequential instruction. 



Opcode 
RNC 



Operand 



Operands are not permitted with the RNC instruction. 



110 10 



Cycles: 1 or 3 

States: 5 or 1 1 (6 or 12 on 8085) 

Addressing: register indirect 

Flags: none 

Example: 

For the sake of brevity, an example is given for the RET instruction but not for each of its closely related 
variants. 



RNZ 



RETURN IF NOT ZERO 



The RNZ instruction tests the zero flag. If the flag is set to zero to indicate that the contents of the accumulator 
are other than zero, the instruction pops two bytes off the stack and places them in the program counter. Pro- 
gram execution resumes at the new address in the program counter. If the flag is set to one, program execution 
simply continues with the next sequential instruction. 



Opcode 
RNZ 



Operand 



Operands are not permitted with the RNZ instruction. 



110 



Cycles: 1 or 3 

States: 5 or 1 1 (6 or 12 on 8085) 

Addressing: register indirect 

Flags: none 

Example: 

For the sake of brevity, an example is given for the RET instruction but not for each of its closely related 
variants. 
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RP 



RETURN IF POSITIVE 



The RP instruction tests the sign flag. If the flag is reset to zero to indicate positive data in the accumulator, 
the instruction pops two bytes off the stack and places them in the program counter. Program execution 
resumes at the new address in the program counter, If the flag is set to one, program execution simply continues 
with the nexi sequential instruction. 



Opcode 
RP 



Operand 



Operands are not permitted with the RP instruction. 



1 1 



1 



10 



Cycles: 1 or 3 

States: 5 or 11 (6 or 12 on 8085) 

Addressing: register indirect 

Flags: none 

Example: 

For the sake of brevity, an example is given for the RET instruction but not for each of its closely related 
variants. 



RPE 



RETURN IF PARITY EVEN 



Parity is ever if the byte in the accumulator has an even number of one bits. The parity flag is set to one to 
indicate this ;ondition. The RPE and RPO instructions are useful for testing the parity of input data. However, 
the IN instruction does not set any of the condition flags. The flags can be set without altering the data by 
adding 00H to the contents of the accumulator, 

The RPE instruction tests the parity flag, if the flag is set to one to indicate even parity, the instruction pops 
two bytes of : the stack and places them in the program counter. Program execution resumes at the new address 
in the program counter. If the flag is zero, program execution simply continues with the next sequential instruc- 
tion. 



Opcode 
RPE 



Operand 



Operands are not permitted with the RPE instruction. 



1110 10 



Cycles: 1 or 3 

States: 5 or 11 (6 or 12 on 8085) 

Addressing: register indirect 

Flags: none 
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Example: 

For the sake of brevity, an example is given for the RET instruction but not for each of its closely related 
variants. 



RPO 



RETURN IF PARITY ODD 



Parity is odd if the byte in the accumulator has an odd number of one bits. The parity flag is reset to zero to 
indicate this condition. The RPO and RPE instructions are useful for testing the parity of input data. However, 
the IN instruction does not set any of the condition flags. The flags can be set without altering the data by 
adding 00H to the contents of the accumulator. 

The RPO instruction tests the parity flag. If the flag is reset to zero to indicate odd parity, the instruction pops 
two bytes off the stack and places them in the program counter. Program execution resumes at the new address 
in the program counter. If the flag is set to one. program execution simply continues with the next sequential 
instruction. 



Opcode 


Operand 




RPO 




Operands are not permitted with the RPO instruction. 






1 1 1 









Cycles: 


1 or 3 




States: 


5 or 11 (6 or 12 on 8085) 


Addressing: 


register indirect 




Flags: 


none 





Example: 

For the sake of brevity, an example is given for the RET instruction but not for each of its closeiy related 
variants. 



RRC 



ROTATE ACCUMULATOR RIGHT 



RRC sets the carry flag equal to the low-order bit of the accumulator, thus overwriting its previous setting. RRC 
then rotates the contents of the accumulator one bit position to the right with the low-order bit transferring to 
the high order position of the accumulator. 



Opcode 
RRC 



Operand 



Operands are not permitted with the RRC instruction. 
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1111 



Cycles: 


1 


States: 


4 


Flags: 


CY only 



Example- 
Assume that the accumulator contains the value OAAH and the carry flag is zero. The fot loving diagrams illus- 
trate the effect of the RRC instruction: 



Before: 



After: 



Carry 




Accumulator 



Carry 



Accumulator 



10 10 10 10 



10 10 10 



RST RESTART 

RST is a special purpose CALL instruction designed primarily for use with interrupts. RST pushes the contents 
of the program counter onto the stack to provide a return address and then jumps to one o eight predetermined 
addresses. A three-bit code carried in the opcode of the RST instruction specifies the jump address. 

The restart instruction is unique because it seldom appears as source code in an applications program. More often, 
the peripheral devices seeking interrupt service pass this one-byte instruction to the processor. 

When a device requests interrupt service and interrupts are enabled, the processor acknowlecges the request and 
prepares its data lines to accept any one-byte instruction from the device. RST is generally he instruction of 
choice because its special purpose CALL establishes a return to the main program. 

The processor moves the three-bit address code from the RST instruction into bits 3 ; 4, anc 5 of the program 
counter, in effect, this multiplies the code by eight. Program execution resumes at the new address where eight 
bytes are available for code to service the interrupt. If eight bytes are too few, the program can either jump to 
or call a subroutine. 
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8085 NOTE 

The 8085 processor includes four hardware inputs that generate internal RST 
instructions. Rather than send a RST instruction, the interrupting device need 
only apply a signal to the RST5.5, RST6.5, RST7.5, or TRAP input pin. 
The processor then generates an internal RST instruction. The execution 
depends on the input: 



INPUT 

NAME 



RESTART 
ADDRESS 



TRAP 
RST5.5 
RST6.5 
RST7.5 



24H 
2CH 
34H 
3CH 



Notice that these addresses are within the same portion of memory used by the RST instruction, and therefore 
allow only four bytes — enough for a call or jump and a return — for the interrupt service routine. 

If included in the program code, the RST instruction has the following format: 

Opcode Operand 

RST code 



The address code must be a number or expression within the range 000B through 111 B. 



Program 
Counter 

After RST 



1 1 



15 14 13 12 11 10 



0000000000 







Cycles: 
States: 

Addressing 
Flags: 



11 (12 on 8085) 
register indirect 
none 



RZ 



RETURN IF ZERO 



The RZ instruction tests the zero flag. If the flag is set to one to indicate that the contents of the accumulator are 
zero, the instruction pops two bytes of data off the stack and places them in the program counter. Program 
execution resumes at the new address in the program counter. If the flag is zero, program execution simply 
continues with the next sequential instruction. 
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Opcode Operand 

RZ 
Operands are not permitted with the RZ instruction. 



110 10 



Cycies: 


1 or 3 


States: 


5 or 11 (6 or 12 on 8085) 


Addressing: 


register indirect 


Fiags: 


none 



Example: 

For the sake of brevity, an example is given for the RET instruction but oot for each of its closely related 
variants. 



S8B SUBTRACT WITH BORROW 

SBB subtracts one byte of data and the setting of the carry flag from the contents of the accumulator. The 
result is stored in the accumulator, SBB then updates the setting of the carry flag to indicate the outcome of 
the operation. 

SBB's use of i he carry flag enables the program to subtract rrulti-byte strings. SBB incorporates the carry flag by 
adding it to the byte to be subtracted from the accumulator . It then subtracts the result from the accumulator 
by using two*, complement addition. These preliminary operations occur in the processor's internal work registers 
so that the source data remains unchanged. 

Subtract Register from Accumulator with Borrow 

Opcode Operand 



SBB 



reg 



The operand must specify one of the registers A through E, H or L. This instruction subtracts the contents of 
the specified agister and the carry flag from the accumulator and stores the result in the accumulator. 



10 11 


S S S 



Cycles: 
States: 
Addressing: 
Flags: 



1 

4 

register 

Z f S,P,CY,AC 
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Subtract Memory from Accumulator with Borrow 

Opcode Operand 

SBB M 



This instruction subtracts the carry fiag and the contents of the memory location addressed by the H and L 
registers from the accumulator and stores the result in the accumulator. 



10 11110 



Cycles: 


2 


States: 


7 


Addressing: 


register indirect 


Flags: 


Z,S,P,CY t AC 



Example: 

Assume that register B contains 2, the accumulator contains 4, and the carry flag is set to 1. The instruction 
SBB B operates as follows: 

2H + carry = 3H 

2's complement of 3H = 11111101 

Accumulator - 00000100 
11111101 
00000001 = 1H 

Notice that this two's complement addition produces a carry, When SBB complements the carry bit generated 
by the addition, the carry flag is reset OFF. The flag settings resulting from the SBB B instruction are as 
follows: 



Carry 


o 


Sign 





Zero 





Parity 





Aux. Carry 


1 



SB! SUBTRACT IMMEDIATE WITH BORROW 

SB! subtracts the contents of the second instruction byte and the setting of the carry flag from the contents of 
the accumulator. The result is stored in the accumulator. 

SBI's use of the carry fiag enables the program to subtract multi-byte strings. SBI incorporates the carry flag by 
adding it to the byte to be subtracted from the accumulator. It then subtracts the result from the accumulator 
by using twos complement addition. These preliminary operations occur in the processor's internal work registers 
so that the immediate source data remains unchanged. 
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The assembler s relocation feature treats all external and relocatable symbols as 16-bit addresses. When one of 
these symbols appears in the operand expression of an immediate instruction, it must be preceded by either the 
HIGH or LOW operator to specify which byte of the address is to be used in the evaluation of the expression. 
When neither operator is present, the assembler assumes the LOW operator and issues an error message. 

Opcode Operand 

SBI data 

The operand nust specify the data to be subtracted. This data may be in the form of a number, an ASCII 
constant, the label of some perviously defined value, or an expression. The data may not exceed one byte. 



110 11110 



Cycles: 2 

States: 7 

Addressing: immediate 

Flags: Z.S.P.CY.AC 

Example: 

The following sequence of instructions enables the program to test the setting of the carry flag: 

XRA A 

SB! 1 

The exclusive OR with the accumulator clears the accumulator to zeros but does not affect the setting of the 
carry flag. (Tie XRA instruction is explained later in this chapter.) When the carry flag is OFF, SBI 1 yields 
a minus one. A/hen the flag is set ON, SBI 1 yields a minus two. 

NOTE 

This example is included for illustrative purposes. In most 
cases, the carry flag can be tested more efficiently by using 
the jNC instruction (jump if no carry), 

SHLD STORE H AND L DIRECT 

SHLD stores \ copy of the L register in the memory location specified in bytes two and three of the SHLD 
instruction. SHLD then stores a copy of the H register in the next higher memory location. 

Opcode Operand 

SHLD address 

The address nay be stated as a number, a previously defined label, or an expression. 
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SHLD is one of the instructions provided for saving the contents of the H and L registers. Alternately, the H 
and L data can be placed in the D and E registers (XCHG instruction) or placed on the stack (PUSH and XTHL 
instructions), 









1 








low addr 


high addr 



Cycles: 


5 


States: 


16 


Addressing: 


direct 


Flags: 


none 



Example: 

Assume that the H and L registers contain OAEH and 29H, respectively, The following is an illustration of the 
effect of the SHLD 10AH instruction: 



Memory Before SHLD 
Memory After SHLD 



MEMORY ADDRESS 


109 


10A 


10B 


10C 


00 


00 


00 


00 


00 


29 


AE 


00 



SIM (8085 PROCESSOR ONLY) 



SET INTERRUPT MASK 



SIM is a multi-purpose instruction that uses the current contents of the accumulator to perform the following 
functions: Set the interrupt mask for the 8085 's RST5.5, RST6.5, and RST7.5 hardware interrupts; reset 
RST7.5*s edge sensitive input; and output bit 7 of the accumulator to the Serial Output Data latch. 



Opcode 



Operand 



SIM 

Operands are not permitted with the SIM instruction. However, you must be certain to load the desired bit 
configurations into the accumulator before executing the SIM instruction. SIM interprets the bits in the accumu- 
lator as follows: 
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7 


6 


5 


4 


3 


2 


1 





OD 


SDE 


XXX 


R7.5 MSE 


M7.5 M6.5 M5.5 



<:: 



= availabie 
masked 



SRST1.S MASK 
< RST6.5 MASK 
UsT5.5 MASK 

/If 0, bits 0-2 ignored 
Mask Set Enable \lf 1 , mask is set 
RESET RST7.5: If 1, RST7.5 flip flop is reset OFF 
*— ignored 
If 1, bit 7 is output to Serial Output Data Latch 
•— Serial Output Data: ignored if bit 6 — 



Accumulator hits 3 and 6 function as enable switches. If bit 3 is set ON (set to 1), the set mask function is 
enabled. Bits through 2 then mask or leave available the corresponding RST interrupt. A 1 bit masks the 
interrupt mak ng it unavailable; a bit leaves the interrupt available. If bit 3 is set OFF (reset to 0), bits 
through 2 have no effect. Use this option when you want to send a serial output bit without affecting the 
interrupt masL 

Notice that the Dl (Disable Interrupts) instruction overrides the SIM instruction. Whether masked or not, RST5.5, 
RST6.5, and UST7.5 are disabled when the Dl instruction is in effect. Use the RIM (Read Interrupt Mask) 
instruction to determine the current settings of the interrupt flag and the interrupt masks, 

If bit 6 is set to 1 , the serial output data function is enabled. The processor latches accumulator bit 7 into the 
SOD output vhere it can be accessed by a peripheral device. If bit 6 is reset to 0, bit 7 is ignored. 

A 1 m accumulator bit 4 resets OFF the RST7.5 input flip flop. Unlike RST5.5 and 6.5, RST7.5 is sensed via a 
processor flip flop that is set when a peripheral device issues a pulse with a rising edge. This edge triggered input 
supports devices that cannot maintain an interrupt request until serviced. RST7.5 is also useful when a device 
does not requ re any explicit hardware service for each interrupt. For example, the program might increment and 
test an event counter for each interrupt rather than service the device directly, 

The RST7.5 f ip flop remains set until reset by 1) issuing a RESET to the 8085, 2) recognizing the interrupt, or 
3) setting accumulator bit 4 and executing a SIM instruction. The Reset RST7.5 feature of the SIM instruction 
allows the program to override the interrupt. 

The RST7.5 input flip flop is not affected by the setting of the interrupt mask or the Dl instruction and there- 
fore can be sec at any time. However, the interrupt cannot be serviced when RST7.5 is masked or a Dl instruction 
is in effect, 



110 



Cycles: 
States: 
Flags: 



1 

4 
none 



Example 1; Assume that the accumulator contains the bit pattern 00011100. The SIM instruction resets the 
RST7.5 flip flop and sets the RST7.5 interrupt mask. If an RST7.5 interrupt is pending when this SIM instruction 
is executed, it is overridden without being serviced. Also, any subsequent RST7.5 interrupt is masked and cannot 
be serviced until the interrupt mask is reset. 
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Example 2: Assume that the accumulator contains the bit pattern 11001111. The SIM instruction masks out the 
RST5.5, RST6.5, and RST7.5 level interrupts and latches a 1 bit into the 50D input. By contrast, the bit pattern 
1000011 1 has no effect since the enable bits 3 and 6 are not set to ones. 



SPHL MOVE H&LTO SP 

SPHL loads the contents of the H and L registers into the SP (Stack Pointer) register. 

Opcode Operand 

SPHL 

Operands are not permitted with the SPHL instruction. 

SP is a special purpose 16-bit register used to address the stack; the stack must be in random access memory 
(RAM). Because different applications use different memory configurations, the user program must load the SP 
register with the stack's beginning address. The stack is usually assigned to the highest available location in RAM. 
The hardware decrements the stack pointer as items are added to the stack and increments the pointer as items 
are removed. 

The stack pointer must be initialized before any instruction attempts to access the stack. Typically, stack 
initialization occurs very early in the program. Once established, the stack pointer should be altered with 
caution. Arbitrary use of SPHL can cause the loss of stack data. 



111110 1 



Cycles: 


1 


States: 


5 (6 on 8085) 


Addressing: 


register 


Flags: 


none 



Example: 

Assume that the H and L registers contain 50H and 0FFH, respectively. SPHL loads the stack pointer with the 
value 50FFH. 



STA STORE ACCUMULATOR DIRECT 

STA stores a copy of the current accumulator contents into the memory location specified in bytes two and 
three of the STA instruction. 

Opcode Operand 

STA address 

The address may be stated as a number, a previously defined label, or an expression. The assembler inverts the 
high and low address bytes when it builds the instruction. 
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110 


1 





low addr 


high addr 



Cycles: 
States: 
Addressing: 
Flags: 



4 
13 

direct 
none 



Example: 

The following instruction stores a copy of the contents of the accumulator at memory location 5B3H: 

STA 5B3H 

When assemble d, the previous instruction has the hexadecimal value 32 B3 05. Notice that the assembler inverts 
the high and low order address bytes for proper storage in memory, 



STAX 



STORE ACCUMULATOR INDIRECT 



The STAX ins ruction stores a copy of the contents of the accumulator into the memory location addressed 
by register par B or register pair D= 



Opcode 



STAX 



Operand 



The operand E specifies the B and C register pair; D specifies the D and E register pair. This instruction may 
specify only the B or D register pair. 






r 


10 



Cycles: 
States: 
Addressing: 
Flags: 






= register 


pair 


B 


1 


= register pair 


D 




2 








7 








register 


ndirect 




none 







Example: 



If register B contains 3FH and register C contains 16H, the following instruction stores a copy of the contents 
of the accumulator at memory location 3F16H: 
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SET CARRY 



STC sets the carry flag to one. No other flags are affected. 

Opcode Operand 

STC 
Operands are not permitted with the STC instruction. 



1 



1 







1 1 



Cycles: 


1 


States: 


4 


Flags: 


CY 



When used in combination with the rotate accumulator through the carry flag instructions, STC allows the pro- 
gram to modify individual bits. 



SUB SUBTRACT 

The SUB instruction subtracts one byte of data from the contents of the accumulator. The result is stored in the 
accumulator, SUB uses two's complement representation of data as explained in Chapter 2. Notice that the SUB 
instruction excludes the carry flag (actually a 'borrow* flag for the purposes of subtraction) but sets the flag to 
indicate the outcome of the operation. 

Subtract Register from A ccumulator 



Opcode 
SUB 



Operand 



The operands must specify one of the registers A through E, H or L. The instruction subtracts the contents of 
the specified register from the contents of the accumulator using two's complement data representation. The 
result is stored in the accumulator. 





1 





1 


J S S S 




Cycles: 
States: 
Addressi 
Flags: 


ng: 




1 

4 

register 

Z,S.P.CY,AC 


Subtract Memory from Accumulator 








Opcode 




Operand 


SUB 






M 
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This instruction subtracts the contents of the memory location addressed by the H and L registers from the 
contents of the accumulator and stores the result in the accumulator, M is a symbolic reference to the H and L 
registers. 



10 10 110 



Cycles: 2 

States: 7 

Addressing: register indirect 

Flags: Z.S.P,CY f AC 

Example: 

Assume that trie accumulator contains 3EH. The instruction SUB A subtracts the contents of the accumulator 
from the accumulator and produces a result of zero as follows: 

3EH = 00111110 

+(~~3EH) = 11000001 one's complement 

1 add one to produce two's complement 

carry out = 1 00000000 result = 

The condition flags are set as follows: 



Carry 


_ 





Sign 


= 





Zero 


= 


1 


Parity 


= 


1 


Aux. Carry 


= 


1 



Notice that the SUB instruction complements the carry generated by the two's complement addition to form a 
'borrow' flag. The auxiliary carry flag is set because the particular value used in this example causes a carry out 
of bit 3. 

SU | SUBTRACT IMMEDIATE 

SU! subtracts the contents of the second instruction byte from the contents of the accumulator and stores the 
result in the ..ccumulator. Notice that the SUI instruction disregards the carry ('borrow') flag during the sub- 
traction but sets the flag to indicate the outcome of the operation. 

Opcode Operand 

SUI data 

The operand must specify the data to be subtracted. This data may be in the form of a number, an ASCII 
constant, the label of some previously defined value, or an expression. The data must not exceed one byte. 

The assemblers relocation feature treats all external and relocatable symbols as 16-bit addresses. When one of 
these symbol . appears in the operand expression of an immediate instruction, it must be preceded by either the 
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HIGH or LOW operator to specify which byte of the address is to be used in the evaluation of the expression. 
When neither operator is present, the assembler assumes the LOW operator and issues an error message. 



110 10 110 



Cycles: 2 

States: 7 

Addressing: immediate 

Flags: Z,S,P,CY,AC 

Example: 

Assume that the accumulator contains the value 9 when the instruction SUI 1 is executed: 

Accumulator = 00001001 = 9H 

Immediate data (2's comp) = 11111111 = -1 H 

00001000 = 8H 

Notice that this two's complement addition results in a carry, The SUI instruction complements the carry 
generated by the addition to form a 'borrow' flag. The flag settings resulting from this operation are as follows: 



Carry 


= 





Sign 


_ 





Zero 


= 





Parity 


= 





Aux. Carry 


= 


1 



XCHG EXCHANGE H AND L WITH D AND E 

XCHG exchanges the contents of the H and L registers with the contents of the D and E registers. 

Opcode Operand 

XCHG 

Operands are not allowed with the XCHG instruction. 

XCHG both saves the current H and L and loads a new address into the H and L registers. Since XCHG is a 
register-to-register instruction, it provides the quickest means of saving and/or altering the H and L registers. 



1110 10 11 



Cycles: 


1 


States: 


4 


Addressing: 


register 


Flags: 


none 
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Example: 



Assume that the H and L registers contain 1234H, and the D and E registers contain OABCDH. Following 
execution of the XCHG instruction, H and L contain OABCDH, and D and E contain 1234H. 



XRA 



EXCLUSIVE OR WITH ACCUMULATOR 



XRA performs an exclusive OR logical operation using the contents of the specified byte and the accumulator, 
The result is pi .iced in the accumulator, 

Summary of Logical Operations 

AND produces a one bit in the result only when the corresponding bits in the test data and the mask data are 
ones. 

OR produces a one bit in the result when the corresponding bits in either the test data or the mask data are 
ones. 

Exclusive OR produces a one bit only when the corresponding bits in the test data and the mask data are 
different; i.e., i one bit in either the test data or the mask data — but not both — produces a one bit in the 
result. 



AND 



OR 



EXCLUSIVE OR 



1010 1010 


1010 1010 


1010 1010 


0000 1111 


0000 1111 


0000 1111 


0000 1010 


1010 1111 


1010 0101 


XRA Register with Accumulator 






Opcode 


Operand 




XRA 


reg 





The operand must specify one of the registers A through E, H or L. This instruction performs an exclusive OR 
using the contents of the specified register and the accumulator and stores the result in the accumulator. The 
carry and auxil ary carry flags are reset to zero. 



10 10 1 


s s s 



Cycles: 


1 


States: 


4 


Addressing: 


register 


Flags: 


Z,S,P ( CY,AC 
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XRA Memory with Accumulator 

Opcode Operand 

XRA M 

The contents of the memory location specified by the H and L registers is exciusive-ORed with the contents of 
the accumulator. The result is stored in the accumulator. The carry and auxiliary carry flags are reset to zero. 



10 10 1110 



Cycles: 2 

States: 7 

Addressing: register indirect 

Flags: Z,S,P,CY,AC 

Examples: 

Since any bit exciusive-ORed with itself produces zero, XRA is frequently used to zero the accumulator. The 
following instructions zero the accumulator and the B and C registers. 

XRA A 

MOV B,A 

MOV C.A 

Any bit exciusive-ORed with a one bit is complemented. Thus, If the accumulator contains all ones (OFFH), 
the instruction XRA B produces the one's complement of the B register in the accumulator. 

XRI EXCLUSIVE OR IMMEDIATE WITH ACCUMULATOR 

XRI performs an exclusive OR operation using the contents of the second instruction byte and the contents of 
the accumulator. The result is placed in the accumulator, XRI also resets the carry and auxiliary carry flags to 
zero. 

Opcode Operand 

XR! data 

The operand must specify the data to be used in the OR operation. This data may be in the form of a number, 
an ASCii constant, the label of some previously defined value, or an expression. The data may not exceed one 
byte. 

The assembler's relocation feature treats ail external and relocatable symbols as 16-bit addresses. When one of 
these symbols appears in the operand expression of an immediate instruction, it must be preceded by either the 
HIGH or LOW operator to specify which byte of the address is to be used in the evaluation of the expression. 
When neither operator is present, the assembler assumes the LOW operator and issues an error message. 
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1110 1110 



data 



Cycles: 2 

States: 7 

Addressing: immediate 

Flags: Z,S,P,CY,AC 

Summary of Logical Operations 

AND produces a one bit in the result only when the corresponding bits in the test data and the mask data are 
ones. 

OR produces ; one bit in the result when the corresponding bits in either the test data or the mask data are 
ones. 

Exclusive OR produces a one bit only when the corresponding bits in the test data and the mask data are 
different; i.e., a one bit in either the test data or the mask data - but not both - produces a one bit in the 
result. 



AND 



OR 



EXCLUSIVE OR 



1010 1010 
0000 1111 



1010 1010 
0000 1111 



0000 1010 1010 1111 



1010 1010 
0000 1111 
1010 0101 



Example: 

Assume that a program uses bits 7 and 6 of a byte as flags that control the calling of two subroutines. The 
program tests the bits by rotating the contents of the accumulator until the desired bit is in the carry flag; a 
CC instructor (Call if Carry) tests the flag and calls the subroutine if required. 

Assume that tie control flag byte is positioned normally in the accumulator, and the program must set OFF bit 
6 and set bit "' ON. The remaining bits, which are status flags used for other purposes, must not be altered. 
Since any bit ^xciusive-ORed with a one is complemented, and any bit exclusive-ORed with a zero remains 
unchanged, tha following instruction is used: 



XRI 



11000000B 



The instruction has the following results: 

Accumulator 
immediate data 



= 01001100 
= 11000000 



10001100 



3-68 



Chapter 3. Instruction Set 



XTHL 



EXCHANGE H&L WITH TOP OF STACK 



XTHL exchanges two bytes from the top of the stack with the two bytes stored in the H and L registers. Thus, 
XTHL both saves the current contents of the H and L registers and loads new values into H and L. 



Opcode 
XTHL 



Operand 



Operands are not allowed with the XTHL instruction. 

XTHL exchanges the contents of the L register with the contents of the memory location specified by the SP 
(Stack Pointer) register. The contents of the H register are exchanged with the contents of SP+1. 



1110 11 



Cycles: 
States: 
Addressing: 
Flags: 



18 (16 on 8085) 
register indirect 
none 



Example: 

Assume that the stack pointer register contains 10ADH; register H contains OBH and L contains 3CH; and 
memory locations 10ADH and 10AEH contain FOH and ODH, respectively. The following is an illustration of 
the effect of the XTHL instruction: 



Before XTHL 
After XTHL 



The stack pointer register remains unchanged following execution of the XTHL instruction. 



MEMORY ADDRESS 


10AC 


10AD 


10AE 


10AF 


FF 
FF 


F0 
3C 


0D 
OB 


FF 
FF 



H 


L 






OB 
0D 


3C 

F0 
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This chapter describes the assembler directives used to control the 8080/85 assembler in its generation of object 
code. This chapter excludes the macro directives, which are discussed as a separate topic in Chapter 5. 

Generally, directives have the same format as instructions and can be interspersed throughout your program. 
Assembler directives discussed in this chapter are grouped as follows: 



AL 


DIRECTIVES: 


9 


Symbol Definition 




EQU 




SET 


• 


Data Definition 




DB 




DW 





Memory Reservation 




DS 





Conditional Assembly 




IF 




ELSE 




ENDIF 



9 Assembler Termination 
END 
LOCATION COUNTER CONTROL AND RELOCATION: 

• Location Counter Control 

ASEG 
DSEG 
CSEG 
ORG 

• Program Linkage 

PUBLIC 
EXTRN 
NAME 
STKLN 
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Three assembler directives — EQU, SET, and MACRO - have a slightly different format from assembly 
language instructions. The EQU, SET, and MACRO directives require a. name for the symbol or macro being 
defined to be present in the label field. Names differ from labels in that they must not be terminated with a 
colon (:) as laaeis are. Also, the LOCAL and ENDM directives prohibit the use of the label field. 



The MACRO, ENDM, and LOCAL directives are explained in Chapter 5. 



SYMBOL DEFINITION 

The assembler automatically assigns values to symbols that appear as instruction labels. This value is the current 
setting of the location counter when the instruction is assembled. (The location counters are explained under 
'Address Cont'd and Relocation,' later in this chapter.) 

You may defi ie other symbols and assign them values by using the EQU and SET directives. Symbols defined 
using EQU cannot be redefined during assembly; those defined by SET can be assigned new values by subsequent 
SET directives. 

The name req jired in the label field of an EQU or SET directive must not be terminated with a colon. 

Symbols defined by EQU and SET have meaning throughout the remainder of the program. This may cause the 
symbol to have illegal multiple definitions when the EQU or SET directive appears in a macro definition. Use 
the LOCAL d rective (described in Chapter 5) to avoid this problem. 



EQU Directive 

EQU assigns tie value of 'expression* to the name specified in the label field. 

Label Opcode Operand 

name EQU expression 

The required uame in the label field may not be terminated with a colon. This name cannot be redefined by a 
subsequent EOU or SET directive. The EQU expression cannot contain any external symbol. (External symbols 
are explained under 'Location Counter Control and Relocation,' later in this chapter.) 

Assembly-tirm evaluation of EQU expressions always generates a modulo 64K address. Thus, the expression 
always yields i value in the range 0-65,536. 

Example: 

The following EQU directive enters the name ONES into the symbol table and assigns the binary value 
11111111 to t: 

ONES EQU OFFH 
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The vaiue assigned by the EQU directive can be recalled in subsequent source lines by referring to its assigned 
name as in the following IF directive: 



IF TYPE EQ ONES 



ENDIF 



SET Directive 

SET assigns the value of 'expression* to the name specified in the label field. 

Label Opcode Operand 

name SET expression 

The assembler enters the value of 'expression' into the symbol table. Whenever 'name' is encountered sub- 
sequently in the assembly, the assembler substitutes its vaiue from the symbol table. This value remains unchanged 
until altered by a subsequent SET directive. 

The function of the SET directive is identical to EQU except that 'name' can appear in multiple SET directives 
in the same program. Therefore, you can alter the value assigned to 'name' throughout the assembly. 

Assembly-time evaluation of SET expressions always generates a modulo 64K address. Thus, the expression 
always yields a value in the range 0-65,536. 



Examples: 



Label 


Opcode 


Operand 


iMMED 


SET 
AD I 


5 
IMMED 


IMMED 


SET 
ADi 


10H-6 
iMMED 



Assembled Code 



C605 



C60A 



DATA DEFINITION 

The DB (define byte) and DW (define word) directives enable you to define data to be stored in your program. 
Data can be specified in the form of 8-bit or 16-bit values, or as a string of text characters. 



DB Directive 

The DB directive stores the specified data in consecutive memory locations starting with the current setting of the 
location counter. 
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Label 



Opcode 



Operands 



optional: 



DB 



expression(s) or string(s) 



The operand leld of the DB directive can contain a list of expressions and/or text strings. The list can contain 
up to eight tc tal items; list items must be separated by commas. Because of limited workspace, the assembler 
may not be a Me to handle a total of eight items when the list includes a number of complex expressions. If 
you ever have this problem, it is easily solved: simply use two or more directives to shorten the list. 

Expressions must evaluate to 1-byte (8-bit) numbers in the range —256 through 255. Text strings may comprise 
a maximum of 128 ASCII characters enclosed in quotes. 

The assembler's relocation feature treats all external and relocatable symbols as 16-bit addresses. When one of 
these symbol: appears in an operand expression of the DB directive, it must be preceded by either the HIGH or 
LOW operate to specify which byte of the address is to be used in the evaluation of the expression. When 
neither opera or is present, the assembler assumes the LOW operator and issues an error message. 

If the option:.! label is present, it is assigned the starting value of the location counter, and thus references 

the first byte stored by the DB directive. Therefore, the label STR in the following examples refers to the letter 

T of the string TIME. 

Examples: 



Label 


Opcode 


Operands 


Assembled Code 


STR: 


DB 


TIME' 


54494D45 


HERE: 


DB 


0A3H 


A3 


WORD!: 


DB 


-03H,5*2 


FDOA 



DW Directive 



The DW direi-tive stores each 16-bit value from the expression list as an address. The values are stored starting 
at the curren setting of the location counter. 



Label 



Opcode 



Operands 



optional: 



DW 



expression list 



The least sigrificant eight bits of the first value in the expression list are stored at the current setting of the 
location courier; the most significant eight bits are stored at the next higher location. This process is repeated 
for each item in the expression list. 

Expressions evaluate to 1— word (16-bit) numbers, typically addresses, if an expression evaluates to a single byte, 
it is assumed to be the low order byte of a 16-bit word where the high order byte is all zeros. 
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List items must be separated by commas. The list can contain up to eight total items. Because of limited work- 
space, the assembler may not be able to handle eight complex expressions. If you ever have this problem, simply 
use two or more DW directives to shorten the list. 

The reversed order for storing the high and low order bytes is the typical format for addresses stored in memory, 
Thus, the DW directive is commonly used for storing address constants. 

Strings containing one or two ASCII characters enclosed in quotation marks may also appear in the expression 
list. When using such strings in your program, remember that the characters are stored in reversed order. 
Specifying a string longer than two characters causes an error. 

If the optional label is present, it is assigned the starting address of the location counter, and thus references the 
first byte stored by the DW directive. (This is the low order byte of the first item in the expression list.) 

Examples: 

Assume that COMP and FILL are labels defined elsewhere in the program. COMP addresses memory location 
3B1CH. FILL addresses memory location 3EB4H. 



Label 


Opcode 


Operands 


Assembled Code 


ADDR1: 


DW 


COMP 


1C3B 


ADDR2: 


DW 


FILL 


B43E 


STRNG: 


DW 


'AVAB* 


41004241 


FOUR: 


DW 


4H 


0400 



MEMORY RESERVATION 
DS Directive 

The DS directive can be used to define a block of storage. 

Label Opcode 

optional: DS 



Operand 
expression 



The value of 'expression' specifies the number of bytes to be reserved for data storage. In theory, this value may 
range from 00H through 0FFFFH; in practice, you will reserve no more storage than will fit in your available 
memory and still leave room for the program. 

Any symbol appearing in the operand expression must be defined before the assembler reaches the DS directive. 

Unlike the DB and DW directives, DS assembles no data into your program. The contents of the reserved storage 
are unpredictable when program execution is initiated. 
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If the optiona label is present, it is assigned the current value of the location counter, and thus references the 
first byte of the reserved memory block. 



if the value ol the operand expression is zero, no memory is reserved. However, if the optional label is present, 
it is assigned the current value of the location counter. 

The DS direct ve reserves memory by incrementing the location counter by the value of the operand expression. 

Example: 

TTYBUF: DS 72 ;RESERVE 72 BYTES FOR 

;A TERMINAL OUTPUT BUFFER 

Programming Tips: Data Description and Access 

Random Access /ersus Read Only Memory 

When coding data descriptions, keep in mind the mix of ROM and RAM in your application. 

Generally, the DB and DW directives define constants, items that can be assigned to ROM. You can use these 
items in your program, but you cannot modify them. If these items are assigned to RAM, they have an initial 
value that yoir program can modify during execution. Notice, however, that these initial values must be reloaded 
into memory :>rior to each execution of the program. 

Variable data n memory must be assigned to RAM, 



Data Description 

Before coding your program, you must have a thorough understanding of its input and output data. But you'll 
probably find it more convenient to postpone coding the data descriptions until the remainder of the program is 
fairly well developed. This way you will have a better idea of the constants and workareas needed in your program. 
Also, the organization of a typical program places instructions in lower memory, followed by the data, followed 
by the stack. 



Data Access 

Accessing date from memory is typically a two-step process: First you tell the processor where to find the data, 
then the processor fetches the data from memory and loads it into a register, usually the accumulator. Therefore, 
the following :ode sequences have the identical effect of loading the ASCII character A into the accumulator. 



AAA: 



DB 



ALPHA: 



DB 



'ABC 



LXI B,AAA 
LDAX B 



LXI B.ALPHA 
LDAX B 
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In the examples, the LXi instructions load the address of the desired data into the B and C registers. The LDAX 
instructions then load the accumulator with one byte of data from the address specified in the B and C registers. 
The assembler neither knows nor cares that only one character from the three-character field ALPHA has been 
accessed. The program must account for the characters at ALPHA+1 and ALPHA+2, as in the following coding 
sequence: 



ALPHA: 



DB 



'ABC 



LXI B.ALPHA 

LDAX B 

INX B 

LDAX B 

INX B 

LDAX B 



;DEFINE ALPHA 

;LOAD ADDRESS OF ALPHA 
;FETCH 1ST ALPHA CHAR 

;SET BTO ALPHA+1 
;FETCH 2ND ALPHA CHAR 

;SET B TO ALPHA+2 
;FETCH 3RD ALPHA CHAR 



The coding above is acceptable for short data fields like ALPHA. For longer fields, you can conserve memory 
by setting up an instruction sequence that is executed repeatedly until the source data is exhausted. 



Add Symbols for Data Access 

The following example was presented earlier as an illustration of the DS directive: 

Label Opcode Operand Comment 

TTYBUF: DS 72 ;RESERVE TTY BUFFER 

To access data in this buffer using only expressions such as TTYBUF+1, TTYBUF+2, . , . TTYBUF+72 can be 
a laborious and confusing chore, especially when you want only selected fields from the buffer. You can simplify 
this task by subdividing the buffer with the EQU directive: 

Label Opcode Operand Comment 

TTYBUF: DS 72 ;RESERVE TTY BUFFER 

ID EQU TTYBUF ;RECORD IDENTIFIER 

NAME EQU TTYBUF+6 ;20-CHAR NAME FIELD 

NUMBER EQU TTYBUF+26 ;10-CHAR EMPLOYEE NUMBER 

DEPT EQU TTYBUF+36 ;5-CHAR DEPARTMENT NUMBER 

SSNO EQU TTYBUF+41 :SOCIAL SEC. NUMBER 

DOH EQU TTYBUF+50 ;DATE OF HIRE 

DESC EQU TTYBUF+56 ;JOB DESCRIPTION 
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Subdividing d; ta as shown in the example simplifies data access and provides useful documentation throughout 
your program. Notice that these EQU directives can be inserted anywhere within the program as you need them, 
but coding th< m as shown in the example provides a more useful record description. 



CONDITIONAL ASSEMBLY 

The IF, ELSE, and ENDiF directives enable you to assemble portions of your program conditionally, that is, 
only if certain conditions that you specify are satisfied. 

Conditional assembly is especially useful when your application requires custom programs for a number of com- 
mon options. As an example, assume that a basic control program requires customizing to accept input from 
one of six dif erent sensing devices and to drive one of five different control devices. Rather than code some 
thirty separate programs to account for all the possibilities, you can code a single program. The code for the in- 
dividual sensos and drivers must be enclosed by the conditional directives. When you need to generate a custom 
program, you can insert SET directives near the beginning of the source program to select the desired sensor and 
driver routine >. 



IF, ELSE, ENDIF Directives 

Because these directives are used in conjunction, they are described together here. 

Label Opcode Operand 

optional: IF expression 

optional: ELSE — - 

optional: ENDIF — 

The assembler evaluates the expression in the operand field of the !F directive, if bit of the resulting value is 
one (TRUE), ill instructions between the IF directive and the next ELSE or ENDIF directive are assembled. 
When bit is zero (FALSE) these instructions are ignored. (A TRUE expression evaluates to OFFFFH and 
FALSE to OH; only bit zero need be tested.) 

All statements included between an IF directive and its required associated ENDIF directive are defined as an 
IF-ENDIF bio;k. The ELSE directive is optional, and only one ELSE directive may appear in an IF-ENDIF 
block. When i icluded, ELSE is the converse of IF, When bit of the expression in the IF directive is zero, all 
statements beiween ELSE and the next ENDIF are assembled. If bit is one, these statements are ignored. 

Operands are tot allowed with the ELSE and ENDIF directives. 

An IF-ENDIF block may appear within another IF-ENDIF block. These blocks can be nested to eight levels. 

Macro definitions (explained in the next chapter) may appear within an IF-ENDIF block. Conversely, IF-ENDIF 
blocks may appear within macro definitions. In either case, you must be certain to terminate the macro definition 
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or IF-ENDIF biock so that it can be assembled completely, For example, when a macro definition begins in an 
IF block but terminates after an ELSE directive, only a portion of the macro can be assembled. Similarly, an 
IF-ENDIF block begun within a macro definition must terminate within that same macro definition. 

NOTE 



Caution is required when symbois are defined in IF-ENDIF 
blocks and referenced elsewhere within the program. These 
symbols are undefined when the evaluation of the IF ex- 
pression suppresses the assembly of the IF-ENDIF block. 



Example 1, Simple IF-ENDIF Block: 
COND1; IF TYPE EQ 



ENDIF 
Example 2. IF-EISE-ENDIF Block: 
COND2: IF TYPE EQ 

ELSE 



ASSEMBLED IF TYPE = 0' 
;IS TRUE 



ASSEMBLED IF TYPE = 0* 
;ISTRUE 



ASSEMBLED IF TYPE 
;1S FALSE 



ENDIF 
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Example 3. Nested IF's: 

C0ND3: IF TYPE EQ 



F MODE EQ 



LEVEL 

1 



LEVEL 
2 



ENDiF 
ELSE 



F MODE EQ 2 



LEVEL ELSE 
1 



ENDIF 
ENDIF 



ASSEMBLED IF TYPE = 0' 
;IS TRUE 



ASSEMBLED IF TYPE == 0' 
;AND 'MODE = T ARE BOTH 
TRUE 



ASSEMBLED IF TYPE = 0' 
;IS FALSE 



ASSEMBLED IF TYPE =0' 
S FALSE AND 'MODE = T 
STRUE 



ASSEMBLED IF TYPE = 5 
AND 'MODE = r ARE BOTH 
FALSE 



ASSEMBLER TERMINATION 

END Directive 

The END directive identifies the end of the source program and terminates each pass of the assembler. 

Label Opcode Operand 

optional: END expression 

Only one END statement may appear in a source program, and it must be the last source statement. 

If the optional expression is present, its value is used as the starting address for program execution. !f no ex- 
pression is gi/en, the assembler assumes zero as the starting address. 

When a number of separate program modules are to be joined together, only one may specify a program starting 
address. The module with a starting address is the main module. When source files are combined using the IN- 
CLUDE control, there are no restrictions on which source file contains the END. 
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Label 


Opcode 




optional: 


EOT 
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END-OF-TAPE INDICATION 

The EOT directive allows you to specify the physical end of paper tape to simplify assembly of multiple-tape source 
programs. 



Operand 



When EOT is recognized by the assembler, the message 'NEXT TAPE' is sent to the console and the assembler pauses. 
After the next tape is loaded, a 'space bar' character received at the console signals continuation of the assembly= 

Data in the operand field causes an error. 



LOCATION COUNTER CONTROL AND RELOCATION 

All the directives discussed in the remainder of this chapter relate directly to program relocation except for the 
ASEG and ORG directives. These directives are described first for the convenience of readers who do not use the 
relocation feature. 



Location Counter Control (Non-Relocatable Mode) 

When you elect not to use the relocation feature, an assembler default generates an ASEG directive for you. The 
ASEG directive specifies that the program is to be assembled in the non-relocatable mode and establishes a 
location counter for the assembly. 

The location counter performs the same function for the assembler as the program counter performs during 
execution, it tells the assembler the next memory location available for instruction or data assembly. 

Initially, the location counter is set to zero. The location counter can be altered by the ORG (origin) directive. 



ORG Directive 

The ORG directive sets the location counter to the value specified by the operand expression. 

Label Opcode Operand 

optional: ORG expression 

The location counter is set to the value of the operand expression. Assembly-time evaluation of ORG expressions 
always yields a modulo 64K address. Thus, the expression always yields an address in the range through 
65,535. Any symbol in the expression must be previously defined. The next machine instruction or data item is | 
assembled at the specified address. 
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If no ORG drective is included before the first instruction or data byte in your program, assembly begins at 
location zero. 

Your program can include any number of ORG directives. Multiple ORG's need not specify addresses in 
ascending sequence, but if you fail to do so, you may instruct the assembler to write over some previously 
assembled postion of the program. 

If the option; I label is present, it is assigned the current value of the location counter before it is updated by the 
ORG directive 

Example: 

I Assume that the current value of the location counter is OFH (decimal 1 5) when the following ORG directive is 

encountered: 

I PaGI: ORG OFFH £>RG ASSEMBLER TO LOCATION 

| ;0FFH (decimal 225) 

IThe symbol FAG1 is assigned the address OFH. The next instruction or data byte is assembled at location 
OFFH. 



Introduction to Repeatability 

A major feature of this assembler is its system for creating relocatable object code modules. Support for this new 
feature includes a number of new directives for the assembler and three new programs included in ISIS-II. The 
three new programs - LIB, LINK, and LOCATE - are described in the ISIS-II System User's Guide. The new 
assembler directives are described later in this chapter. 

Repeatability allows the programmer to code programs or sections of programs without worrying about the 
final arrangement of the object code in memory. This offers developers of microcomputer systems major ad- 
vantages in two areas: memory management and modular program development. 



Memory Management 

When developing, testing, and debugging a system on your Intellec microcomputer development system, your 
oniy concern with locating a program is that it doesn't overlap the resident routines of ISIS-II. Because the 
Intellec systen has 32K, 48K, or 64K of random access memory, the location of your future program is not a 
great concern. However, the program you are developing will almost certainly use some mix of random access 
memory (RAM), read-only memory (ROM), and/or programmable read-only memory (PROM). Therefore, the 
location of y^ur program affects both cost and performance in your application. The relocatability feature allows 
you to develop, test, and debug your program on the intellec development system and then simply relocate the 
object code io suit your application. 

The relocatability feature also has a major advantage at assembly-time: often, large programs with many symbols 
cannot be assembled because of limited work space for the symbol table. Such a program can be divided into a 
number of modules that can be assembled separately and then linked together to form a single object program. 
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Modular Program Development 

Although 'repeatability' may seem to be a formidable term, what it really means is that you can subdivide a 
complex program into a number of smaller, simpler programs. This concept is best illustrated through the use of 
an example. Assume that a microcomputer program is to control the spark advance on an automobile engine. 
This requires the program to sample the ambient air temperature, engine air intake temperature, coolant tempera- 
ture, manifold vacuum, idle sensor, and throttle sensor. 

Let us examine the approaches two different programmers might take to solve this problem. Both programmers 
want to calculate the degree of spark advance or retardation that provides the best fuel economy with the lowest 
emissions. Programmer A codes a single program that senses all inputs and calculates the correct spark advance. 
Programmer B uses a modular approach and codes separate programs for each input plus one program to calculate 
spark advance. 

Although Programmer A avoids the need to learn to use the repeatability feature, the modular approach used 
by Programmer B has a number of advantages you should consider: 

• Simplified Program Development 

It is generally easier to code, test, and debug several simple programs than one complex program. 

• Sharing the Programming Task 

If Programmer B finds that he is falling behind schedule, he can assign one or more of his sub- 
programs to another programmer. Because of his single program concept, Programmer A will 
probably have to complete the program himself. 

• Ease of Testing 

Programmer B can test and debug most of his modules as soon as they are assembled; Programmer 
A must test his program as a whole. Notice that Programmer B has an extra advantage if the 
sensors are being developed at the same time as the program. If one of the sensors is behind 
schedule, Programmer B can continue developing and testing programs for the sensors that are 
ready, Because Programmer A cannot test his program until ail the sensors are developed, his 
testing schedule is dependent on events beyond his control. 

• Programming Changes 

Given the nature of automotive design, it is reasonable to expect some changes during system 
development. If a change to one of the sensors requires a programming change, Programmer A 
must search through his entire program to find and alter the coding for that sensor. Then he must 
retest the entire program to be certain that those changes do not affect any of the other sensors. 
By contrast, Programmer B need be concerned only with the module for that one sensor. This 
advantage continues throughout the life of the program. 
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DIRECTIVES USED FOR RELOCATION 

Several direc lives have been added to the assembler to support the relocation feature. These fall into the general 
categories of location counter control and program linkage. 

Location Counter Control (Relocatable Programs) 

Relocatable urograms or program modules may use three location counters. The ASEG, DSEG, and CSEG 
directives specify which location counter is to be used. 

The ASEG cirective specifies an absolute code segment. Even in a relocatable program module, you may want 
to assign certain code segments to specific addresses. For example, restart routines invoked by the RST instruc- 
tion require specific addresses. 

The CSEG cirective specifies a relocatable code segment. In general, the CSEG location counter is used for por- 
tions of the program that are to be in some form of read-only memory, such as machine instructions and pro- 
gram constaits. 

The DSEG ocation counter specifies a relocatable data segment. This location counter is used for program 
elements th it must be located in random access memory, 

These direc ives allow you to control program segmentation at assembly time. The LOCATE program, described 
m the ISIS-1I System User's Guide, gives you control over program segment location. Therefore, the guidelines 
given above are only general since they can be overridden by the LOCATE program. 

Regardless of how many times the ASEG, CSEG, and DSEG directives appear in your program, the assembler 
produces a single, contiguous module. This module comprises four segments: code, data, stack and memory, 
The LINK md LOCATE programs are used to combine segments from individual modules and relocate them in 
memory, T lese programs are explained in the ISIS-II System User's Guide. 



ASEG Directh e 

ASEG directs the assembler to use the location counter for the absolute program segment. 

Label Opcode Operand 

optional: ASEG — 

Operands are not permitted with the ASEG directive. 

All instruc ions and data following the ASEG directive are assembled in the absolute mode. The ASEG directive 
remains in effect until a CSEG or DSEG directive is encountered. 

The ASEG location counter has an initial value of zero. The ORG directive can be used to assign a new value to 
the ASEG location counter. 
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When assembly begins, the assembler assumes the ASEG directive to be in effect. Therefore, a CSEG or DSEG 
must precede the first instruction or data definition in a reiocatabie module. If neither of these directives 
appears in the program, the entire program is assembled in absolute mode and can be executed immediately 
after assembly without using the LINK or LOCATE programs. 



CSEG Directive 

CSEG directs the assembler to assemble subsequent instructions and data m the relocatable mode using the code 
segment location counter. 

Label Opcode Operand 

f blank "1 
optional: CSEG <^ PAGE S 

IJNPAGeJ 

When a program contains multiple CSEG directives, all CSEG directives throughout the program must specify 
the same operand. The operand of a CSEG directive has no effect on the current assembly, but is stored with 
■the object code to be passed to the LINK and LOCATE programs. (These programs are described in the ISIS-II 
System User's Guide.) The LOCATE program uses this information to determine relocation boundaries when it 
joins this code segment to code segments from other programs. The meaning of the operand is as follows: 

« blank - This code segment may be relocated to the next available byte boundary, 

• PAGE - This code segment must begin on a page boundary when relocated. Page boundaries 
occur in multiples of 256 bytes beginning with zero (0, 256, 512, etc.). 

e INPAGE - This code segment must fit within a single page when relocated. 

The CSEG directive remains in effect until an ASEG or DSEG directive is encountered. 

The code segment location counter has an initial value of zero. The ORG directive can be used to assign a new 
value to the CSEG location counter. 



DSEG Directive 

DSEG directs the assembler to assemble subsequent instructions and data in the relocatable mode using the data 
segment location counter. 

Label Opcode Operand 

( blank "| 
optional: DSEG J PAGE > 



\ INPAGE J 



When multiple DSEG directives appear in a program, they must all specify the same operand throughout the 
program. The operands for the DSEG directive have the same meaning as for the CSEG directive except that 
they apply to the data segment. 
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There is no irteraction between the operands specified for the DSEG and CSEG directives. Thus, a code segment 
can be byte relocatable while the data segment is page relocatable. 

The DSEG directive remains in effect until an ASEG or CSEG directive is encountered. 

The data segment location counter has an initial value of zero. The ORG directive can be used to assign a new 
value to the DSEG location counter. 



ORG Directive (Relocatable Mode) 

The ORG directive can be used to alter the value of the location counter presently in use. 

Label Opcode Operand 

optional: ORG expression 

There are thr ie location counters, but only one location counter is in use at any given point in the program. 
Which one depends on whether the ASEG, CSEG, or DSEG directive is in effect. 

Any symbol used in the operand expression must have been previously defined. An exception causes phase 
errors for all abels that follow the ORG and a label error if the undefined error is defined later. 

When the ORG directive appears in a relocatable program segment, the value of its operand expression must be 
either absolute or relocatable within the current segment. Thus, if the ORG directive appears within a data seg- 
ment, the value of its expression must be relocatable within the data segment. An error occurs if the expression 
evaluates to < n address in the code segment. 

If the option ii label is present, it is assigned the current value of the location counter presently in use before 
the ORG directive is executed. 

Program Linkage Directives 

Modular programming and the relocation feature enable you to assemble and test a number of separate programs 
that are to bs joined together and executed as a single program. Eventually, it becomes necessary for these 
separate programs to communicate information among themselves. Establishing such communication is the 
function of Ihe program linkage directives. 

A program may share its data addresses and instruction addresses with other programs. Only items having an 
entry in the symbol table can be shared with other programs; therefore, the item must be assigned a name or a 
label when it is defined in the program. Items to be shared with other programs must be declared in a PUBLIC 
directive. 

Your program can directly access data or instructions defined in another program if you know the actual 
address of the item, but this is unlikely when both programs use relocation. Your program can also gain access 
to data or instructions declared as PUBLIC in other programs. Notice, however, that the assembler normally 
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flags as an error any reference to a name or label that has not been defined in your program. To avoid this, 
you must provide the assembler with a list of items used in your program but defined in some other program. 
These items must be declared in an EXTRN directive. 

The two remaining program linkage directives, NAME and STKLN, are individually explained later in this chapter. 



PUBLIC Directive 

The PUBLIC directive makes each of the symbols listed in the operand field available for access by other programs. 

Label Opcode Operands 

optional: PUBLIC name-list 

Each item in the operand name-list must be the name or label assigned to data or an instruction elsewhere in 
this program. When multiple names appear in the list, they must be separated by commas. Each name may be 
declared PUBLIC only once in a program module. Reserved words and external symbols (see the EXTRN 
directive below] cannot be declared to be PUBLIC symbols. 

PUBLIC directives may appear anywhere within a program module. 

If an item in the operand name-list has no corresponding entry in- the symbol table (implying that it is unde- 
fined), it is flagged as an error. 

Example: 

PUBLIC 3IN,COS,TAN,SQRT 

EXTRN Directive 

The EXTRN directive provides the assembler with a list of symbols referenced in this program but defined in a 
different program. Because of this, the assembler establishes linkage to the other program and does not flag the 
undefined references as errors. 

Label Opcode Operands 

optional: EXTRN name-list 

Each item in the name-list identifies a symbol that may be referenced in this program but is defined in another 
program. When multiple items appear in the list, they must be separated by commas. 

If a symbol in the operand name—list is also defined in this program by the user, or is a reserved symbol, the effect 
is the same as defining the same symbol more than once \n a program. The assembler flags this error. 

EXTRN directives may appear anywhere within a program module. 

A symbol may be declared to be external only once in a program module. Symbols declared to be PUBLIC cannot 
also be declared to be EXTRN symbols. 
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If you omit a symbol from the name-list but reference it in the program, the symbol is undefined. The assembler 
flags this erro\ You may include symbols in the operand name-list that are not referenced in the program with- 
out causing an error. 

Example: 

EXTRN ENTRY 1 ADDRTN,BEGIN 

NAME Directive 

The NAME directive assigns a name to the object module generated by this assembly, 

Label Opcode Operand 

optional: NAME module-name 

The NAME directive requires the presence of a module— name in the operand field. This name must conform to 
the rules for iefining symbols. 

Module names are necessary so that you can refer to a module and specify the proper sequence of modules 
when a number of modules are to be bound together. 

The NAME directive must precede the first data or instruction coding in the source program, but may follow 
comments and control lines. 

If the NAME directive is missing from the program, the assembler supplies a default NAME directive with the 
module-nama MODULE. This will cause an error if you attempt to bind together several object program 
modules and more than one has the name MODULE. Also, if you make an error coding the NAME directive, 
the default name MODULE is assigned. 

The module-name assigned by the NAME directive appears as part of the page heading in the assembly listing. 

Example: 

NAME MAIN 

STKLN Directhe 

Regardless 01 the number of object program modules you may bind together, only one stack is generated. The 
STKLN direttive allows you to specify the number of bytes to be reserved for the stack for each module. 

Label Opcode Operand 

optional: STKLN expression 

The operand expression must evaluate to a number which will be used as the maximum size of the stack. 
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When the STKLN directive is omitted, the assembler provides a default STKLN of zero. This is useful when 
multiple programs are bound together; only one stack will be generated, so only one program module need 
specify the stack size. However, you should provide a 5TKLN if your module is to be tested separately and 
uses the stack. 

If your program includes more than one STKLN directive, only the last value assigned is retained. 

Example: 

STKLN 100 

STACK and MEMORY Reserved Words 

The reserved words STACK and MEMORY are not directives but are of interest to programmers using the 
relocation feature. These reserved words are externa! references whose addresses are supplied by the LOCATE 
program. 

STACK is the symbolic reference to the stack origin address. You need this address to initialize the stack 
pointer register. Also, you can base data structures on this address using symbolic references such as STACK+1 , 
STACK+2, etc. 

MEMORY is the symbolic reference to the first byte of unused memory past the end of your program. Again, 
you can base data structures on this address using symbolic references such as MEMORY, MEMORY+1, etc. 

Programming Tips: Testing Relocatable Modules 

The ability to test individual program modules is a major advantage of modular programming. However, many 
program modules are not logically self-sufficient and require some modification before they can be tested. The 
following is a discussion of some of the more common modifications that may be required. 

Initialization Routines 

In most complete programs, a number of housekeeping or initialization procedures are performed when execution 
first begins. If the program moduie you are testing relies on initialization procedures assigned to a different 
module, you must duplicate those procedures in the module to be tested. (Notice, however, that you can link 
any number of modules together for testing.) 

One of the most important initialization procedures is to set the stack pointer. The LOCATE program determines 
the origin of the stack. 

Your program should include the following instruction to initialize the stack pointer: 

LX) SP,STACK 
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InputjOutput 

When testing program modules, it is likely that some input or output procedures appear in other modules. Your 
program must simulate any of these procedures it needs to operate. Since your Inteilec development system 
probably has considerably more random access memory than you need to test a program module, you may be 
able to simulaie input and output data right in memory, The LOCATE program supplies an address for the 
reserved word MEMORY; this is the address of the first byte of unused memory past the end of your program. 
You can acces. this memory using the symbolic reference MEMORY, MEMORY+1, and so on. This memory 
can be used for storing test data or even for a program that generates test data. 



Remove Coding Used for Testing 

After testing your program, be certain to remove any code you inserted for testing, In particular, make certain 
that only one module in the complete program initializes the stack pointer. 
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INTRODUCTION TO MACROS 

Why Use Macros? 

A macro is essentially a facility for replacing one set of parameters with another. In developing your program, 
you will frequently find that many instruction sequences are repeated several times with only certain parameters 
changed. 

As an example, suppose that you code a routine that moves five bytes of data from one memory location to 
another. A little later, you find yourself coding another routine to move four bytes from a different source 
fieid to a different destination field. If the two routines use the same coding techniques, you will find that 
they are identical except for three parameters: the character count, the source field starting address, and the 
obstipation field starting address. Certainly it would be handy if there were some way to regenerate that original 
routine substituting the new parameters rather than rewrite that code yourself. The macro facility provides this 
capability and offers several other advantages over writing code repetstiously; 

• The tedium of frequent rewrite (and the probability of error) is reduced. 

© Symbols used in macros can be restricted so that they have meaning only within the macro itself. 
Therefore, as you code your program, you need not worry that you will accidentally duplicate a 
symbol used in a macro. Also, a macro can be used any number of times in the same program 
without duplicating any of its own symbols. 



@ 



An error detected in a macro need be corrected only once regardless of how many times the macro 
appears in the program. This reduces debugging time. 



® Duplication of effort between programmers can be reduced. Useful functions can be collected in a 
library to allow macros to be copied into different programs. 

In addition, macros can be used to improve program readability and to create structured programs. Using macros 
to segment code blocks provides clear program notation and simplifies tracing the flow of the program. 

What Is A Macro? 

A macro can be described as a routine defined in a formal sequence of prototype instructions that, when called 
within a program, results in the replacement of each such call with a code expansion consisting of the actual 
instructions represented. 
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The concepts cf macro definition, call, and expansion can be illustrated by a typical business form letter, where 
the prototype nstructions consist of preset text. For example, we could define a macro CNFIRM with the text 

Air Fi ght welcomes you as a passenger. 

Your light number FNO leaves at DTIME and arrives in DEST at ATIME, 

This macro has four dummy parameters to be replaced, when the macro is called, by the actual flight number, 
departure time destination, and arrival time. Thus the macro call might look like 

CNFIRM 123, '10:45', 'Ontario', '11:52*. 

A second macro, CAR, could be called if the passenger has requested that a rental car be reserved at the desti- 
nation airport. This macro might have the text 

Your automobile reservation has been confirmed with MAKE rent-a-car agency, 
Finally, a macio GREET could be defined to specify the passenger name. 

Dear ;\fAME: 
The entire tex : of the business letter (source file) would then look like 

GREET 'Ms. Scanner 

CNFKM 123, '10:45', 'Ontario', '11:52* 

CAR ; Blotz' 

We trjst you wilt enjoy your flight. 

Since ely. 

When this source file is passed through a macro processor, the macro calls are expanded to produce the following 

letter. 

Dear Vis. Scannel: 

Air Fight welcomes you as a passenger. Your flight number 123 leaves at 10:45 and arrives 
in Ortario at 11:52. Your automobile reservation has been confirmed with Blotz rent-a-car 

agency. 

We trust you will enjoy your flight. 

Since'eiy, 

While this example illustrates the substitution of parameters in a macro, it overlooks the relationship of the macro 
processor and the assembler. The purpose of the macro processor is to generate source code which is then 
assembled. 
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Macros Vs. Subroutines 

At this point, you may be wondering how macros differ from subroutines invoked by the CALL instruction. 
Both aid program structuring and reduce the coding of frequently executed routines. 

One distinction between the two is that subroutines necessarily branch to another part of your program while 
macros generate in-line code. Thus, a program contains only one version of a given subroutine, but contains as 
many versions of a given macro as there are calls for that macro. 

Notice the emphasis on 'versions' in the previous sentence, for this is a major difference between macros and 
subroutines. A macro does not necessarily generate the same source code each time it is called. By changing the 
parameters in a macro call, you can change the source code the macro generates. In addition, macro parameters 
can be tested at assembly-time by the conditional assembly directives. These two tools enable a general-purpose 
macro definition to generate customized source code for a particular programming situation. Notice that macro 
expansion and any code customization occur at assembly-time and at the source code level. By contrast, a 
generalized subroutine resides in your program and requires execution time. 

It is usually possible to obtain similar results using either a macro or a subroutine. Determining which of these 
facilities to use is not always an obvious decision. In some cases, using a single subroutine rather than multiple 
in-line macros can reduce the overall program size, in situations involving a large number of parameters, the use 
of macros may be more efficient. Also, notice that macros can call subroutines, and subroutines can contain 
macros. 



USING MACROS 

The assembler recognizes the following macro operations: 

© MACRO directive 

© ENDM directive 

© LOCAL directive 

© REPT directive 

© IRP directive 

© IRPC directive 

© EXITM directive 

© Macro call 

All of the directives listed above are related to macro definition. The macro call initiates the parameter sub- 
stitution (macro expansion) process. 

Macro Definition 

Macros must be defined in your program before they can be used. A macro definition is initiated by the MACRO 
assembler directive, which lists the name by which the macro can later be called, and the dummy parameters to 
be replaced during macro expansion. The macro definition is terminated by the ENDM directive. The prototype 
instructions bounded by the MACRO and ENDM directives are called the macro body. 
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When label symbols used in a macro body have 'global* scope, multiply-defined symbol errors result if the macro 
is called more than once. A label can be given limited scope using the LOCAL directive. This directive assigns a 
unique value :o the symbol each time the macro is called and expanded. Dummy parameters also have limited 
scope. 

Occasionally vou may wish to duplicate a block of code several times, either within a macro or in line with 
other source code. This can be accomplished with minimal coding effort using the REPT (repeat block), 1RP 
(indefinite repeat), and IRPC (indefinite repeat character) directives. Like the MACRO directive, these directives 
are terminated by ENDM. 

The EXITM cirective provides an alternate exit from a macro. When encountered, it terminates the current macro 
just as if ENDM had been encountered. 



Macro Definition Directives 

MACRO Directive 

Label Opcode Operand 

name MACRO optional dummy parameter(s) 

The name in :he label field specifies the name of the macro body being defined. Any valid user-defined symbol 
name can be jsed as a macro name. Note that this name must be present and must not be terminated by a colon. 

A dummy parameter can be any valid user-defined symbol name or can be null. When multiple parameters are listed, 
they must be .eparated by commas. The scope of a dummy parameter is limited to its specific macro definition. If a 
reserved symtol is used as a dummy parameter, its reserved value is not recognized. For example, if you code 
A,B,C as a dummy parameter list, substitutions will occur properly. However, you cannot use the accumulator 
or the 8 and C registers within the macro. Because of the limited scope of dummy parameters, the use of these 
registers is not affected outside the macro definition. 

Dummy parameters in a comment are not recognized. No substitution occurs for such parameters. 

Dummy parameters may appear in a character string. However, the dummy parameter must be adjacent to an 
ampersand character (&) as explained later in this chapter. 

Any machine instruction or applicable assembler directive can be included in the macro body. The distinguishing 
feature of macro prototype text is that parts of it can be made variable by placing substitutable dummy param- 
eters in instruction fields. These dummy parameters are the same as the symbols in the operand field of the 
MACRO directive. 

Example: 

Define macro MAC! with dummy parameters Gl , G2, and G3. 
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NOTE 



The foliowing macro definition contains a potential error 
that is clarified In the description of the LOCAL directive 
iater in this chapter. 



;MACRO DIRECTIVE 
;MACRO BODY 



MAC1 


MACRO 


G1 f G2 f G3 


MOVES. 


LHLD 


G1 




MOV 


A,M 




LHLD 


G2 




MOV 


B,M 




LHLD 


G3 




MOV 


C,M 




ENDM 





;ENDM DIRECTIVE 



ENDM Directive 



Label Opcode 

ENDM 



Operand 



The ENDM directive is required to terminate a macro definition and follows the last prototype instruction. It is 
also required to terminate code repetition blocks defined by the REPT. IRP, and IRPC directives. 

Any data appearing in the label or operand fields of an ENDM directive causes an error. 

NOTE 

Because nested macro calls are not expanded during macro 
definition, the ENDM directive to close an outer macro can- 
not be contained in the expansion of an inner, 'nested' 
macro call. (See 'Nested Macro Definitions' later in this 
chapter.) 

LOCA L Directive 



Label 



Opcode 



LOCAL 



Operand 



label name(s) 



The specified label names are defined to have meaning only within the current macro expansion. Each time the 
macro is called and expanded, the assembler assigns each local symbol a unique symbol in the form ??nnnn. 

The assembler assigns ??0001 to the first local symbol, ??0002 to the second, and so on. The most recent symbol 
name generated always indicates the total number of symbols created for all macro expansions. The assembler 
never duplicates these symbols. The user should avoid coding symbols in the form ??nnnn so that there will not 
be a conflict with these assembler-generated symbols. 
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Dummy parameters included in a macro cai) cannot be operands of a LOCAL directive. The -cope of a dummy 
parameter is always local to its own macro definition. 

Local symbols can be defined only within a macro definition. Any number of LOCAL direct ves may appear in 
a macro definition, but they must all follow the macro call and must precede the first line oi prototype code. 

A LOCAL directive appearing outside a macro definition causes an error. Also, a name appearing in the label 
field of a LOCAL directive causes an error. 

Example: 

The definition of MAO (used as an example in the description of the MACRO directive) contains a potential 
error because the symbol MOVES has not been declared local. This is a potential error since no error occurs if 
MAC1 is called only once in the program, and the program itself does not use MOVES as a symbol. However, 
if MAC1 is called more than once, or if the program uses the symbol MOVES, MOVES is a multiply-defined 
symbol. This potential error is avoided by naming MOVES in trre operand field of a LOCAL directive: 



MAC1 



MOVES. 



MACRO 


G1,G2,G3 


LOCAL 


MOVES 


LHLD 


Gl 


MOV 


A,M 


LHLD 


G2 


MOV 


B,M 


LHLD 


G3 


MOV 


C,M 


ENDM 





Assume that MAC! is the only macro in the program and that it is called twice. The first tine MAC1 is expanded, 
MOVES is replaced with the symbol ? ?0001; the second time, MOVES is replaced with ? ?0002. Because the 
assembler encounters only these special replacement symbols, the program may contain the symbol MOVES 
without causing a multiple definition. 



Directive 










Label 


Opcode 


Operand 




optional: 


REPT 


expression 



The REPT directive causes a sequence of source code lines to be repeated 'expression' times. All lines appearing 
between the REPT directive and a subsequent ENDM directive constitute the block to be restated. 

When 'expression' contains symbolic names, the assembler must encounter the definition of he symbol prior to 
encountering the expression. 

The insertion of repeat blocks is performed in-line when the assembler encounters the REPT directive. No 
explicit call is required to cause the code insertion since the definition is an implied call for expansion. 
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Example 1 : 

Rotate accumulator right six times. 



ROTR6: 



REPT 

RRC 

ENDM 



Exampie 2: 

The following REPT directive generates the source code for a routine that fiils a five-byte field with the character 
stored in the accumulator: 



PROGRAM CODE 



GENERA TED CODING 



LHLD 


CNTR1 


LHLD 


CNTR1 


REPT 


5 


MOV 


M,A 


MOV 


M,A 


INX 


H 


INX 


H 


MOV 


M.A 


ENDM 




INX 


H 






MOV 


M.A 






INX 


H 






MOV 


M.A 






INX 


H 






MOV 


M.A 






INX 


H 



Exampie 3: 

The following example illustrates the use of REPT to generate a multiplication routine. The multiplication is 
accomplished through a series of shifts. If this technique is unfamiliar, refer to the example of multiplication 
in Chapter 6. The exampie in Chapter 6 uses a program loop for the multiplication. This exampie replaces the 
loop with seven repetitions of the four instructions enclosed by the REPT-ENDM directives. 

Notice that the expansion specified by this REPT directive causes the label SKI PAD to be generated seven times. 
Therefore, SKiPAD must be declared local to this macro. 



FSTMUL: 



SKIPAD: 



MVI 


D,0 :I 


LXI 


H.O ;f 


REPT 


; 

7 


LOCAL 


SKIPAD 


RLC 




JNC 


SKiPAD ;; 


DAD 


D ;; 


DAD 


H 


ENDM 




RLC 




RNC 




DAD 


D 


RET 





FAST MULTIPLY ROUTINE 
MULTIPLY E*A - 16-BIT RESULT 
IN H&L 



;GET NEXT MULTIPLIER BIT 

DONT ADD IF BIT = 

ADD MULTIPLICAND INTO ANSWER 
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This example i iustrates a classic programming trade-off: speed versus memory. Although this example executes 
more quickly nan the example in Chapter 6, it requires more memory, 



IRP Directive 



Label 



Opcode 



Operand 



optional: 



IRP 



dummy param, <list> 



The operand field for the IRP (indefinite repeat) directive must contain one macro dummy parameter followed 
by a list of actual parameters enclosed in angle brackets. IRP expands its associated macro prototype code sub- 
stituting the fist actual parameter for each occurrence of the dummy parameter. IRP then expands the proto- 
type code agah substituting the second actual parameter from the list. This process continues until the list is 
exhausted. 

The list of act jai parameters to be substituted for the dummy parameter must be enclosed in angle brackets 
(< >). Individu; I items in the list must be separated by commas. The number of actual parameters In the list 
controls the number of times the macro body is repeated; a list of n items causes n repetitions. An empty list 
(one with no parameters coded) specifies a null operand list. IRP generates one copy of the macro body sub- 
stituting a null for each occurrence of the dummy parameter. Also, two commas with no intervening character 
create a null parameter within the list. (See 'Special Operators'' later in this chapter for a description of null 
operands.) 



Example: 

The following code sequence gathers bytes of data from different areas of memory and then stores them in 
consecutive b\ tes beginning at the address of STORiT: 



PROGRAM CODE 



GENERATED CODING 



LXI 


H.STORIT 


LXI 


H.STORIT 


IRP 


X 1 <FLD1,3E20H,FLD3> 


LDA 


FLD1 


LDA 


X 


MOV 


M,A 


MOV 


M,A 


INX 


H 


INX 


H 


LDA 


3E20H 


ENDM 




MOV 


M,A 






INX 


H 






LDA 


FLD3 






MOV 


M.A 






INX 


H 



IRPC Directive 










Label 


Opcode 


Operand 




optional: 


1RPC 


dummy param, text 
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The IRPC (indefinite repeat character) directive causes a sequence of macro prototype instructions to be repeated 
for each text character of the actuai parameter specified. If the text string is enclosed in optional angle brackets, 
any delimiters appearing in the text string are treated simply as text to be substituted into the prototype code. 
The assembler generates one iteration of the prototype code for each character in the text string. For each 
iteration, the assembler substitutes the next character from the string for each occurrence of the dummy param- 
eter A list of n text characters generates n repetitions of the IRPC macro body, An empty string specifies a 
null actual operand. IRPC generates one copy of the macro body substituting a null for each occurrence of the 
dummy parameter. 

Example: 



PROGRAM CODE 



GENERA TED CODING 



MVDATE: 



LHLD DATE-1 

IRPC X,1977 

INX H 

MVI M.X 
EN DM 



LHLD 


DATE-1 


INX 


H 


MVI 


M,1 


INX 


H 


MVI 


M,9 


INX 


H 


MVI 


M,7 


INX 


H 


MVI 


M,7 



IRPC provides the capability to treat each character of a string individually; concatenation (described later in this 
chapter) provides the capability for building text strings from individual characters. 



EXITM Directive 



Label 



Opcode 



Operand 



optional: 



EXITM 



EXITM provides an alternate method for terminating a macro expansion or the repetition of a REPT, iRP, or 
IRPC code sequence. When EXITM is encountered, the assembler ignores all macro prototype instructions 
located between the EXITM and ENDM directive for this macro. Notice that EXITM may be used in addition 
to ENDM, but not in place of ENDM. 

When used in nested macros, EXITM causes an exit to the previous level of macro expansion. An EXITM within 
a REPT, IRP, or IRPC terminates not only the current expansion, but all subsequent iterations as well. 

Any data appearing in the operand field of an EXITM directive causes an error. 

Example: 

EXITM is typically used to suppress unwanted macro expansion. In the following example, macro expansion is 
terminated when the EXITM directive is assembled because the condition X EQ is true. 
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MAC3 MACRO X,Y 



IF X EQO 
EX1TM 



ENDM 



Special Macro Operators 

In certain spec ai cases, the normal ruies for dealing with macros do not work. Assume, for example, that you 
want to specify three actual parameters, and the second parameter happens to be the comma character. To the 
assembler, the list PARM1„,PARM3 appears to be a list of four parameters where the second and third param- 
eters are missing. The list can be passed correctly by enclosing the comma in angle brackets: PARM1 ,<,>,PARM3. 
These special operators instruct the assembler to accept the enclosed character (the comma) as an actual param- 
eter rather tha i a delimiter. 

The assembler recognizes a number of operators that allow special operations: 

& Ampersand. Used to concatenate (link) text and dummy parameters. See the further 

discussion of ampersands below. 

<> Angle brackets. Used to delimit text, such as lists, that contain other delimiters. 

Notice that blanks are usually treated as delimiters. Therefore, when an actual 
parameter contains blanks (passing the instruction MOV A,M, for example) the 
parameter must be enclosed in angie brackets. This is also true for any other de- 
limiter that is to be passed as part of an actual parameter. To pass such text to 
nested macro calls, use one set of angle brackets for each level of nesting. (See 
'Nested Macro Definitions/ below.) 

;; Double semicolon. Used before a comment in a macro definition to prevent 

inclusion of the comment in expansions of the macro and reduce storage 
requirements. The comment still appears in the listing of the definition. 

! Exclamation point (escape character). Placed before a character (usually a 

delimiter) to be passed as literalized text in an actual parameter. Used primarily 
to pass angie brackets as part of an actual parameter. To pass a literalized 
exclamation point, issue !L Carriage returns cannot be passed as actual parameters. 

The '!' is always preserved while building an actual parameter. It is not 
echoed when an actual parameter is substituted for a dummy parameter, 
except when the substitution is being used to build another actual parameter. 
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NUL In certain cases it is not necessary to pass a parameter to a macro. It is 

necessary, however, to indicate the omission of the parameter. The omitted 
(or null) parameter can be represented by two consecutive delimiters as in 
the list PARM1„PARM3, A null parameter can also be represented by two 
consecutive single quotes: ",PARM2,PARM3. Notice that a null is quite 
different from a blank: a blank is an ASCII character with the hexadecimal 
representation 20H; a null has no character representation. In the assembly 
listing a null looks the same as a blank, but that is only because no substi- 
tution has taken place. The programmer must decide the meaning of a null 
parameter. Although the mechanism is somewhat different, the defaults taken 
for assembler controls provide a good example of what a null parameter can 
mean. For example, coding MOD85 as an assembler control specifies that 
the assembler is to generate object code for the 8085. The absence of this 
control (which in effect is a null parameter) specifies that the assembler 
is to generate only 8080 object code. 

Assembler controls are explained in the ISfS-li 8080 j 808 5 Macro Assembler 
Operator's Manual, 9800292. 

Example: 

In a macro with the dummy parameters W,X,Y,Z it is acceptable for either 
the X or Y parameter to be null, but not both. The following IF directive 
tests for the error condition: 

IF NUL X&Y 
EXITM 

When a macro is expanded, any ampersand preceding or following a dummy parameter in a macro definition is 
removed and the substitution of the actual parameter occurs at that point. When it is not adjacent to a dummy 
parameter, the ampersand is not removed and is passed as part of the macro expansion text. 

NOTE 

The ampersand must be immediately adjacent to the text being 
concatenated; intervening blanks are not allowed. 

If nested macro definitions (described below) contain ampersands, the only ampersands removed are those adiacent 
to dummy parameters belonging to the macro definition currently being expanded. All ampersands must be re- 
moved by the time the expansion of the encompassing macro body is performed. Exceptions force illegal character 
errors. 

Ampersands placed inside strings are recognized as concatenation delimiters when adjacent to dummy parameters; 
similarly, dummy parameters within character strings are recognized only when they are adjacent to ampersands. 
Ampersands are not recognized as operators in comments. 
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Nested Macro Delmitions 

A macro definition can be contained completely within the body of another macro definition (that is, macro 
definitions can be nested). The body of a macro consists of att text (including nested macro definitions) 
bounded by matching MACRO and ENDM directives. The assembler allows any number of macro definitions to 
be nested. 

When a higher- eve! macro is called for expansion, the next lower-level macro is defined and eligible to be called 
for expansion. A lower-level macro cannot be called unless all higher-level macro definitions have already been 
called and expanded. 

A new macro may be defined or an existing macro redefined by a nested macro definition depending on whether 
the name of the nested macro is a new label or has previously been established as a dummy parameter in a 
higher-level macro definition. Therefore, each time a higher-level macro is called, a lower-level definition can be 
defined differently if the two contain common dummy parameters. Such redefinition can be costly, however, in 
terms of assembler execution speed. 

Since IRP, I RFC, and REPT blocks constitute macro definitions, they also can be nested within another definition 
created by IRF, 1RPC, REPT, or MACRO directives. In addition, an element in an IRP or iRPC actual parameter 
list (enclosed in angle brackets} may itself be a list of bracketed parameters; that is, lists of parameters can contain 
elements that < re also lists. 

Example: 

LISTS MACRO PARAM1 ,PARAM2 



ENDM 



LISTS <A, <B,C» 



MACRO CALLS 



Once a macro las been defined, it can be called any number of times in the program. The call consists of the 
macro name and any actual parameters that are to replace dummy parameters during macro expansion. During 
assembly, each macro call is replaced by the macro definition code; dummy parameters are replaced by actual 
parameters. 



Macro Call Format 



Label 


Opcode 


Operand 


optional: 


macro name 


optional actual 
parameter(s) 
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The assembler must encounter the macro definition before the first call for that macro. Otherwise, the macro 
cail is assumed to be an illegal opcode. The assembler inserts the macro body identified by the macro name 
each time it encounters a call to a previously defined macro in your program. 

The positioning of actual parameters in a macro call is critical since the substitution of parameters is based 
solely on position. The first-listed actual parameter replaces each occurrence of the first-listed dummy param- 
eter; the second actual parameter replaces the second dummy parameter, and so on. When coding a macro call, 
you must be certain to list actual parameters in the appropriate sequence for the macro. 

Notice that blanks are usually treated as delimiters. Therefore, when an actual parameter contains blanks 
(passing the instruction MOV A.M, for example) the parameter must be enclosed in angle brackets. This is also 
true for any other delimiter that is to be passed as part of an actual parameter. Carriage returns cannot be passed 
as actual parameters. 

If a macro call specifies more actual parameters than are listed in the macro definition, the extra parameters 
are ignored. If fewer parameters appear in the cail than in the definition, a null replaces each missing parameter. 

Example: 

The following example shows two calls for the macro LOAD. LOAD is defined as follows: 

LOAD MACRO G1.G2.G3 

LOCAL MOVES 

MOVES: 



LHLD 


G1 


MOV 


A.M 


LHLD 


G2 


MOV 


B,M 


LHLD 


G3 


MOV 


CM 


ENDM 





LOAD simply loads the accumulator with a byte of data from the location specified by the first actual parameter, 
the B register with a byte from the second parameter, and the C register with a byte from the third parameter. 

The first time LOAD is called, it is used as part of a routine that inverts the order of three bytes in memory, 
The second time LOAD is called, it is part of a routine that adds the contents of the B register to the accumu- 
lator and then compares the result with the contents of the C register. 
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MAIN PROGRAM 



JNZ ME 


:XT 


LOAC 


FLD,FLD+l,FLD+2 


MOV 


M,A iiNVERT BYTES 


DCX 


H 


MOV 


M.B 


DCX 


H 


MOV 


M,C 


LOAD 


3E0H,BYTE,CHECK 


ADD 


B ;CHECK DIGIT 


CMP 


C 


CNZ 


DGTBAD 



??0001 : 



?0002: 



SUBSTITUTION 


JNZ 


NEXT 


LHLD 


FLD 


MOV 


A,M 


LHLD 


FLD+1 


MOV 


B,M 


LHLD 


FLD+2 


MOV 


CM 


MOV 


M,A ;INVERT BYTES 


DCX 


H 


MOV 


M.B 


DCX 


H 


MOV 


M,C 


LHLD 


3E0H 


MOV 


A,M 


LHLD 


BYTE 


MOV 


B.M 


LHLD 


CHECK 


MOV 


C,M 


ADD 


B ;CHECK DIGIT 


CMP 


C 


CNZ 


DGTBAD 



Nested Macro Calls 

Macro cails (including any combination of nested IRP, IRPC, and REPT constructs) can be nested within macro 
definitions up to eight levels. The macro being called need not be defined when the enclosing macro is defined; 
however, it mist be defined before the enclosing macro is called. 

A macro defin tion can also contain nested calls to itself (recursive macro calls) up to eight levels, as long as the 
recursive macro expansions can be terminated eventually, This operation can be controlled using the conditional 
assembly direc:ives described in Chapter 4 (IF, ELSE, ENDIF). 

Example: 

Have a macro :all itself five times after it is called from elsewhere in the program. 



PARAM1 
RECALL 



SET 5 

MACRO 



IF PARAM1 NE 

PARAM1 SET PARAM1-1 

RECALL 
ENDIF 



RECURSIVE CALL 



ENDM 



5-14 



Chapter 5. Macros 



Macro Expansion 

When a macro is called, the actual parameters to be substituted into the prototype code can be passed in one of 
two modes. Normally, the substitution of actual parameters for dummy parameters is simpiy a text substitution. 
The parameters are not evaluated until the macro is expanded. 

If a percent sign (%} precedes the actual parameter in the macro call, however, the parameter is evaluated 
immediately, before expansion occurs, and is passed as a decimal number representing the value of the param- 
eter. In the case of IRPC, a '%* preceding the actual parameter causes the entire text string to be treated as a 
single parameter. One IRPC iteration occurs for each digit in the decimal string passed as the result of immediate 
evaluation of the text string. 

The norma! mechanism for passing actual parameters is adequate for most applications. Using the percent sign 
to pre-evaluate parameters is necessary only when the value of the parameter is different within the local con- 
text of the macro definition as compared to its global value outside the macro definition. 

Example: 

The macro shown in this example generates a number of rotate instructions. The parameters passed in the macro 
call determine the number of positions the accumulator is to be rotated and whether rotate right or rotate left 
instructions are to be generated. Some typical calls for this macro are as follows: 

SHIFTR 'R',3 

SHiFTR L,%COUNT-l 

The second call shows an expression used as a parameter. This expression is to be evaluated immediately rather 
than passed simply as text. 

The definition of the SHIFTR macro is shown beiow. This macro uses the conditional IF directive to test the 
validity of the first parameter. Also, the REPT macro directive is nested within the SHIFTR macro. 

SHiFTR MACRO X.Y 

IF X EQ 'R 1 
REPT Y 
RAR 
ENDM 
END1F 
IF X NE 'L 1 

EXITM 
ELSE 
REPT Y 
RAL 
ENDM 
ENDIF 
ENDM 

The indentation shown in the definition of the SHIFTR macro graphically illustrates the relationships of the IF, 
ELSE, ENDIF directives and the REPT, ENDM directives. Such indentation is not required in your program, but 
may be desirable as documentation. 

5-15 



Chapter 5. Macros 



The SHiFTR macro generates nothing if the first parameter is neither R nor L. Therefore, the following calls 
produce no code. The result in the object program is as though the SHIFTR macro does not appear in the 
source program. 

SHIFTR 5 

SHiFTR 'B\2 

The following call to the SHiFTR macro generates three RAR instructions: 

SHIFTR 'R',3 

Assume that i SET directive elsewhere in the source program has given COUNT the value 6. The following call 
generates five RAL instructions: 

SHIFTR «L\%COUNT-1 

The following is a redefinition of the SHiFTR macro. In this definition, notice that concatenation is used to 
form the RAM. or RAL operation code. If a call to the SHIFTR macro specifies a character other than R or L, 
illegal operation codes are generated. The assembler flags all illegal operation codes as errors. 

SHIFTR MACRO X.Y 

REPT Y 

RA&X 
ENDM 
ENDM 



NULL MACROS 



A macro may legally comprise only the MACRO and ENDM directives. Thus, the following is a legal macro 
definition: 

NADA MACRO PI ,P2,P3,P4 

ENDM 

A call to this macro produces no source code and therefore has no effect on the program. 

Although these is no reason to write such a macro, the null (or empty) macro body has a practical application. 
For example, all the macro prototype instructions might be enclosed with IF-ENDIF conditional directives. 
When none oi the specified conditions is satisfied, all that remains of the macro is the MACRO directive and 
the ENDM directive. 



SAMPLE MACROS 

The following sample macros further demonstrate the use of macro directives and operators. 
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Example 1: Nested IRPC 

The following macro definition contains a nested IRPC directive. Notice that the third operand of the outer 
macro becomes the character string for the IRPC: 



MOVE 



MACRO 


X.Y.Z 


IRPC 


PARAM.Z 


LHLD 


X&&PARAM 


SHLD 


Y&&PARAM 


ENDM 




ENDM 





Assume that the program contains the call MOVE SRC.DST.123. The third parameter of this call is passed to 
the IRPC. This has the same effect as coding IRPC PARAM.123. When expanded, the MOVE macro generates 
the following source code: 

LHLD SRC1 

SHLD DST1 

LHLD 5RC2 

SHLD DST2 

LHLD SRC3 

SHLD DST3 

Notice the use of concatenation to form labels in this example. 

Example 2: Nested Macros Used to Generate DB Directives 

This example generates a number of DB directives, each with its own label, Two macros are used for this 
purpose: INC and BLOCK. The INC macro is defined as follows: 



INC 


MACRO 


F1,F2 


$ SAVE GEN 






F1&F2: 


DB 





$ RESTORE 


ENDM 





GENERATE LABELS & DB's 



The BLOCK macro, which accepts the number of DB's to be generated (NUMB) and a label prefix (PREFIX), is 
defined as follows: 



BLOCK MACRO 

SAVE NOGEN 
COUNT SET 

REPT 
COUNT SET 

INC 

ENDM 
RESTORE 

ENDM 



NUMB.PREFIX 



NUMB 

COUNT+1 

PREF!X,%COUNT ;NESTED MACRO CALL 
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The macro ca I BLOCK 3, LAB generates the following source code: 





BLOCK 


3, LAB 


LABI: 


DB 





LAB2: 


DB 





LAB3: 


DB 






The assembtei controls specified in these two macros (the Sines beginning with $) are used to clean up the 
assembly listing for easier reading. The source code shown for the call BLOCK 3, LAB is what appears in the 
assembly listing when the controls are used. Without the controls, the assembly listing appears as follows: 





BLOCK 


3.LAB 


COUNT 


SET 







REPT 


3 


COUNT 


SET 


COUNT+1 




INC 


LAB,%COUNT 




ENDM 




COUNT 


SET 


COUNT+1 




INC 


LAB,%COUNT 


LABI: 


DB 





COUNT 


SET 


COUNT+1 




INC 


LAB,%COUNT 


LAB2: 


DB 





COUNT 


SET 


COUNT+1 




INC 


LAB,%COUNT 


LAB3: 


DB 






Example 3: \ Macro that Converts Itself into a Subroutine 

In some cases, the in-line coding substituted for each macro call imposes an unacceptable memory requirement. 
The next three examples show three different methods for converting a macro call into a subroutine call. The 
first time the SBMAC macro is called, it generates a full in-line substitution which defines the SUBR subroutine. 
Each subsequent call to the SBMAC macro generates only a CALL instruction to the SUBR subroutine. 

Within the fo lowing examples, notice that the label SUBR must be global so that it can be called from outside 
the first expansion, This is possible only when that part of the macro definition containing the global label is 
called only once in the entire program. 

Method #1: Nested Macro Definitions 

Macros can b<2 redefined during the course of a program. In the following example, the definition of SBMAC 
contains its ovvn redefinition as a nested macro. The first time SBMAC is called, it is full expanded, and the 
redefinition of SBMAC replaces the original definition. The second time SBMAC is called, only its redefinition 
(a CALL instruction) is expanded. 
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SBMAC 


MACRO 




SBMAC 


MACRO 






CALL 


SUBR 




ENDM 






CALL 


SUBR 


LINK: 


JMP 


DUN 


SUBR: 







;;REDEFlNiTION OF SBMAC 



DUN: 



RET 



ENDM 



Notice that both versions of SBMAC contain CALL SUBR instructions. This is necessary to provide a return 
address at the end of the SUBR routine. The jump instruction Sabelled LINK is required to prevent the SUBR 
subroutine from executing a return to itself. Notice that the return address for the second CALL SUBR 
instruction would be SUBR if the jump instruction were omitted. The JMP DUN instruction simply transfers 
control past the end of the subroutine. 

NOTE 

The assembler allows the use of a source line consisting 
only of a label. Such a label is assigned to the next source 
line for which code or data is generated. Notice that 
neither code nor data is generated for an ENDM directive, 
so the label DUN is assigned to whatever instruction follows 
the ENDM directive. This construct is required because the 
ENDM directive itself may not be given a label. 

Method #2: Conditional Assembly 

The second method for altering the expansion of the SBMAC macro uses conditional assembly. In this example, 
a switch (FIRST) is set TRUE just before the first call for SBMAC. SBMAC is defined as follows: 



TRUE 


EQU 


OFFH 


FALSE 


EQU 





FIRST 


SET 


TRUE 


SBMAC 


MACRO 
CALL SUBR 






IF 


FIRST 


FIRST 


SET 


FALSE 


LINK: 


JMP 


DUN 


SUBR: 







DUN: 



RET 

ENDIF 
ENDM 
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The first call o SBMAC expands the ful! definition, including the cal! to and definition of SUBR: 





SBMAC 






CALL 


SUBR 




IF 


FIRST 


LINK: 


jMP 


DUN 


SUBR: 







DUN: 



RET 



ENDIF 



Because FIRST is TRUE when encountered during the first expansion of SBMAC, ail the statements between 
IF and ENDIF are assembled into the program. In subsequent calls, the conditionally-assembled code is skipped 
so that the subroutine is not regenerated. Only the following expansion is produced: 



SBMAC 

CALL 

IF 



SUBR 
FIRST 



Method #3: Conditional Assembly with EXITM 

The third method for altering the expansion of SBMAC also uses conditional assembly, but uses the EXiTM 
directive to si ppress unwanted macro expansion after the first call. EXITM is effective when FIRST is FALSE, 
which it is afier the first call to SBMAC. 



TRUE 


EQU 


OFFH 


FALSE 


EQU 





FIRST 


SET 


TRUE 


SBMAC 


MACRO 






CALL 


SUBR 




IF 


NOT FIRST 




EXITM 






ENDIF 




FIRST 


SET 


FALSE 




jMP 


DUN 


SUBR: 







DUN: 



RET 



ENDM 
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Example 4: Computed GOTO Macro 

This sample macro presents an implementation of a computed GOTO for the 8080 or 8085. The computed 
GOTO, a common feature of many high level languages, allows the program to jump to one of a number of 
different locations depending on the value of a variable. For example, if the variable has the value zero, the 
program jumps to the first item in the list; if the variable has the value 3, the program jumps to the fourth 
address in the list. 

In this example, the variable is placed in the accumulator, The list of addresses is defined as a series of DW 
directives starting at the symbolic address TABLE. This macro (TJUMP) also modifies itself with a nested 
definition. Therefore, only the first call to the TJUMP macro generates the calculated GOTO routine. Subse- 
quent calls produce only the jump instruction JMP TJCODE. 



TJUMP 


MACRO 


;J 


TJCODE: 


ADD 


A ; 




MV! 


D,0 ;( 




MOV 


E,A ;< 




DAD 


D ;, 




MOV 


E.M ;( 




INX 


H 




MOV 


DM ;( 




XCHG 






PCHL 


;J 


TJUMP 


MACRO 


; 




JMP 


TJCODE ;f 




ENDM 






ENDM 





JUMP TO A-TH ADDR IN TABLE 

MULTIPLY A BY 2 

CLEAR D REG 

;GET TABLE OFFSET INTO D&E 

ADD OFFSET TO TABLE ADDR IN H&L 

GET 1ST ADDRESS BYTE 

;GET 2ND ADDRESS BYTE 

JUMP TO ADDRESS 

REDEFINE TJUMP TO SAVE CODE 

NEXT GALL JUMPS TO ABOVE CODE 



Notice that the definition of the TJUMP macro does not account for loading the address of the address table 
into the H and L registers; the user must load this address just before calling the TJUMP macro. The following 
shows the coding for the address table (TABLE) and a typical call sequence for the TJUMP macro: 



MVI 
LXI 
TJUMP 



A,2 
HTABLE 



TABLE: 



DW 


LOCO 


DW 


LOC1 


DW 


LOC2 



The call sequence shown above causes a jump to LOC2. 
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Example 5: Using IRP to Define the Jump Tabie 

The TjUMP macro becomes even more useful when a second macro (GOTO) is used to define the jump table, 
load the address of the table into the H and L registers, and then call TJUMP, The GOTO macro is defined as 
follows: 

GOTO 

LOCAL JTABLE 

LOAD ACCUM WITH INDEX 
LOAD H&L WITH TABLE ADDRESS 
;CALL TJUMP MACRO 



JTABLE: 



MACRO 


INDEX, LIST 


LOCAL 


JTABLE 


LDA 


INDEX 


LX! 


HJTABLE 


TJUMP 




IRP 


FORMALXL 


DW 


FORMAL 


ENDM 




ENDM 





;SET UP TABLE 



A typical call to the GOTO macro would be as follows: 

GOTO CASE,<COUNT,TIMER,DATE,PTDRVR> 

This call to tLe GOTO macro builds a table of DW directives for the labels COUNT, TIMER, DATE, and 
PTDRVR. (t hen loads the base address of the table into the H and L registers and calls the TJUMP macro. 
If the value o : the variable CASE is 2 when the GOTO macro is called, the GOTO and TJUMP macros 
together caus* a jump to the address of the DATE routine. 

Notice that any number of addresses may be specified in the list for the GOTO routine as long as they all fit 
on a single sojree line. Also, the GOTO macro may be called any number of times, but only one copy of the 
coding for the TJUMP is generated since the TJUMP macro redefines itself to generate only a JMP TJCODE 
instruction. 
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This chapter describes some techniques that may be of help to the programmer. 



BRANCH TABLES PSEUDO-SUBROUTINE 

Suppose a program consists of several separate routines, any of which may be executed depending upon some 
initial condition (such as a number passed m a register). One way to code this would be to check each condition 
sequentially and branch to the routines accordingly as follows: 

CONDITION = CONDITION V 
IF YES BRANCH TO ROUTINE 1 
CONDITION = CONDITION 2? 
IF YES BRANCH TO ROUTINE 2 



BRANCH TO ROUTINE N 

A sequence as above is inefficient, and can be improved by using a branch table. 

The logic at the beginning of the branch table program loads the starting address of the branch table into the H 
and L registers. The branch table itself consists of a list of starting addresses for the routines to be branched to. 
Using the H and L registers as a pointer, the branch table program loads the selected routine's starting address 
into the program counter, thus effecting a jump to the desired routine. For example, consider a program that 
executes one of eight routines depending on which bit of the accumulator is set: 



Jump to routine 1 if the accumulator holds 00000001 



00000010 
00000100 
00001000 
00010000 
00100000 
01000000 
10000000 



A program that provides such logic follows. The program is termed a 'pseudo-subroutine 1 because it is treated as a 
subroutine by the programmer (i.e., it appears just once in memory), but is entered via a regular JUMP instruction 
rather than via a CALL instruction. 
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Main Prcgram 



Branch Table 
Program 



Jump 
Routines 




normal subroutine return 
sequence not followed by 
branch table program 
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Label 


Code 


Operand 


START: 


LX! 


H.BTBL 


GTBIT: 


RAR 






JC 


GETAD 




INX 


H 




INX 


H 




JMP 


GTBIT 


GETAD: 


MOV 


E,M 




INX 


H 




MOV 


D,M 




XCHG 





PCHL 



REGISTERS H AND L WILL 
;POINT TO BRANCH TABLE 



;(H.L)=(H.L)+2TO 

;POINT TO NEXT ADDRESS 

;IN BRANCH TABLE 

BIT FOUND 

LOAD JUMP ADDRESS 

INTO D AND E REGISTERS 

EXCHANGE D AND E 
;WITH H AND L 
;jUMPTO ROUTINE 
;ADDRESS 



BTBL: 



DW 


ROUT! 


DW 


ROUT2 


DW 


ROUTS 


DW 


ROUT4 


DW 


ROUT5 


DW 


ROUT6 


DW 


ROUT7 


DW 


ROUT8 



BRANCH TABLE. EACH 

ENTRY IS A TWO-BYTE 

ADDRESS 

HELD LEAST SIGNIFICANT 

BYTE FIRST 



The control routine at START uses the H and L registers as a pointer into the branch table (BTBL) corresponding 
to the bit of the accumulator that is set. The routine at GETAD then transfers the address held in the corres- 
ponding branch table entry to the H and L registers via the D and E registers, and then uses a PCHL instruction, 
thus transferring control to the selected routine. 



TRANSFERRING DATA TO SUBROUTINES 

A subroutine typically requires data to perform its operations. In the simplest case, this data may be transferred 
in one or more registers. 

Sometimes it is more convenient and economical to let the subroutine load its own registers. One way to do this 
is to place a list of the required data (called a parameter list) in some data area of memory, and pass the address 
of this list to the subroutine in the H and L registers. 
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For example, the subroutine ADSUB expects the address of a three-byte parameter iist in the H and L registers, 
ft adds the fh st and second bytes of the list, and stores the result in the third byte of the list: 



Label 



Code 


Operand 


Comment 


LXI 
CALL 


H.PLIST 
ADSUB 


;LOAD H AND L WITH 
;ADDRESSES OF THE PARAM- 
ETER LIST 
;CALL THE SUBROUTINE 



RET1: 






3 LiST; 


DB 


6 




DB 


8 




DS 


1 




LXi 


H,LIST2 




CALL 


ADSUB 


RET2: 






LIST2: 


DB 


10 




DB 


35 




DS 


1 


DSUB: 


MOV 


A,M 




INX 


H 




MOV 


B,M 




ADD 


B 




INX 


H 




MOV 


M,A 



;F!RST,NUMBER TO BE ADDED 

;SECOND NUMBER TO BE 

;ADDED 

;RESULT WILL BE STORED HERE 

;LOAD H AND L REGISTERS 

FOR ANOTHER CALL TO ADSUB 



RET 



;GET FIRST PARAMETER 

INCREMENT MEMORY 

ADDRESS 

GET SECOND PARAMETER 

ADD FIRST TO SECOND 

INCREMENT MEMORY 

ADDRESS 

STORE RESULT AT THIRD 

PARAMETER STORE 

RETURN UNCONDITIONALLY 



The first time ADSUB is called, it loads the A and B registers from PLIST and PLIST+1 respectively, adds them, 
and stores tre result in PLIST+2. Return is then made to the instruction at RET1. 
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First call to ADSUB: 



ADSUB: 



H L 

□ □ 





06 


PLIST 


08 


PL1ST+1 


OEH 


PLIST+2 





The second time ADSUB is called, the H and L registers point to the parameter list LIST2. The A and B 
registers are loaded with 10 and 35 respectively, and the sum is stored at LIST2+2. Return is then made to 
the instruction at RET2. 

Note that the parameter lists PLIST and LIST2 could appear anywhere in memory without altering the results 
produced by ADSUB. 

This approach does have its limitations, however. As coded, ADSUB must receive a list of two and only two 
numbers to be added, and they must be contiguous in memory. Suppose we wanted a subroutine (GENAD) 
which would add an arbitrary number of bytes, located anywhere in memory, and leave the sum in the accumu- 
lator. 

This can be done by passing the subroutine a parameter list which is a list of addresses of parameters, rather 
than the parameters themselves, and signifying the end of the parameter list be a number whose first byte is 
FFH (assuming that no parameters will be stored above address FF00H). 

Call to GENAD: 



GENAD: 



















/ 












8 


PARM1 




/ 














16 






L 


ADR1 


V 


PARM4 




ADR2 






N 








ADR3 


~k\ 


13 


PARM3 




ADR4 


W 














* 


82 






FFFF 


PARM2 













As implemented below, GENAD saves the current sum (beginning with zero) in the C register. It then loads the 
address of the first parameter into the D and E registers, if this address is greater than or equal to FF00H, it 
reloads the accumulator with the sum held in the C register and returns to the calling routine. Otherwise, it 
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loads the parameter into the accumulator and adds the sum in the C register to the accumulator. The routine 
then loops b;ick to pick up the remaining parameters. 



Label 


Code 


Operand 


Comment 




LXS 


H.PLIST 


;LOAD ADDRE< 




CALL 


GENAD 


•PARAMETER / 




HALT 






PL1ST: 


DW 


PARM1 


;LISTOF PARA 




DW 


PARM2 






DW 


PARM3 






DW 


PARM4 






DW 


OFFFFH 


;TERMI-NATOR 


PARM1; 


DB 


6 




PARM4: 


DB 


16 





PARM3: 



FARM2: 



DB 



DB 



13 



82 



GENAD: 


XRA 


A 


LOOP: 


MOV 


C.A 




MOV 


E,M 




INX 


H 




MOV 


A,M 




CP! 


OFFH 




JZ 


BACK 




MOV 


D,A 




LDAX 


D 




ADD 


C 




INX 


H 




jMP 


LOOP 


BACK: 


MOV 
RET 
END 


A,C 



CLEAR ACCUMULATOR 
;SAVE CURRENT TOTAL IN C 
;GET LOW ORDER ADDRESS BYTE 
;OF FiRST PARAMETER 

GET HIGH ORDER ADDRESS BYTE 
OF FiRST PARAMETER 
COMPARE TO FFH 
IF EQUAL, ROUTINE IS COMPLETE 
D AND E NOW ADDRESS PARAMETER 
LOAD ACCUMULATOR WITH PARAMETER 
ADD PREVIOUS TOTAL 
INCREMENT H AND L TO POINT 
TO NEXT PARAMETER ADDRESS 
;GET NEXT PARAMETER 
ROUTINE DONE - RESTORE TOTAL 
RETURN TO CALLING ROUTINE 
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Note that GENAD could add any combination of the parameters with no change to the parameters themselves. 

The sequence: 

LX! H.PLiST 

CALL GENAD 



PLIST: DW PARM4 

DW PARM1 

DW OFFFFH 

would cause PARM1 and PARM4 to be added, no matter where in memory they might be located (excluding 
addresses above FFOOH). 

Many variations of parameter passing are possible. For example, if it is necessary to allow parameters to be 
stored at any address, a calling program can pass the total number of parameters as the first parameter; the 
subroutine then loads this first parameter into a register and uses it as a counter to determine when all param- 
eters had been accepted. 



SOFTWARE MULTIPLY AND DIVIDE 

The multiplication of two unsigned 8-bit data bytes may be accomplished by one of two techniques: repetitive 
addition, or use of a register shifting operation. 

Repetitive addition provides the simplest, but slowest, form of multiplication. For example, 2AH*74H may be 
generated by adding 74H to the (initially zeroed) accumulator 2AH times. 

Shift operations provide faster multiplication. Shifting a byte left one bit is equivalent to multiplying by 2, and 
shifting a byte right one bit is equivalent to dividing by 2. The following process will produce the correct 2-byte 
result of multiplying a one byte multiplicand by a one byte multiplier 

A. Test the least significant bit of multiplier. If zero, go to step b. If one, add the 
multiplicand to the most significant byte of the result. 

B. Shift the entire two-byte result right one bit position, 

C. Repeat steps a and b until all 8 bits of the multiplier have been tested. 
For example, consider the multiplication: 2AH*3CH=9D8H 

Step 1: Test multiplier 0-bit; it is 0, so shift 16-bit result right one bit. 

Step 2: Test multiplier 1-bit; it is 0, so shift 16-bit result right one bit. 

Step 3: Test multiplier 2-bit; it is 1, so add 2AH to high-order byte of result and shift 16-bit 
result right one bit. 
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Step 4: Test multiplier 3-bit; it is 1 , so add 2AH to high-order byte of result and shift 16-bit 
result right one bit. 

Step 5: Test multiplier 4-bit; it is 1 , so add 2AH to high-order byte of result and shift 16-bit 
result right one bit. 

Step 6: Test multiplier 5-bit; it is 1 , so add 2AH to high-order byte of result and shift 16-bit 
result right one bit. 

Step 7: Test multiplier 6-bit; it is 0, so shift 16-bit result right one bit. 

Step 8: Test multiplier 7-bit; it is 0, so shift 16-bit result right one bit. 

The result produced is 09D8. 



HIGH-ORDER BYTE 

MULTIPLIER MULTIPLICAND OF RESULT 

Start 001 1 1 1 00(3C) 001 01 01 0(2 A) 00000000 
Step 1 a , , . . , , . . . . , , . . . . . . . . . . : . . . • . > > . . 

b 00000000 

Step 2 a ....,.,.., , . ,..,,..>.,. , = . . . . . . 

b 00000000 

Step 3a ..,,,.... 00101010 

b 00010101 

Step 4 a.,. ,..,.,,...,.,...,,,,,., = ,... 00111111 

b 00011111 

Step 5 a ............................... 01001001 

b 00100100 

Step 6a, .,.,.,,,.,....,.,,......,..... 01001110 

b 00100111 
Step 7 a ,.....,..,,.,... . .............. = 

b 00010011 

Step 8a,....,....,.,........-....--... 

b 00001001 



LOW-ORDER BYTE 
OF RESULT 
00000000 

00000000 

00000000 
00000000 
00000000 
00000000 
10000000 
10000000 
11000000 
11000000 

on ooooo 

10110000 
11011000{9D8) 



Since the multiplication routine described above uses a number of important programming techniques, a sample 
program is g-ven with comments. 

The program uses the B register to hold the most significant byte of the result, and the C register to hold the 
least significant byte of the result. The 16-bit right shift of the result is performed in the accumulator by two 
rotate-right-through-carry instructions. 
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Zero carry and then rotate B: 
B 



► X 



Then rotate C to complete the shift: 
B 



Register D holds the multiplicand, and register C originally holds the multiplier, 



MULT: 



MULTO: 



MVI 



MVI 


E,9 


MOV 


A,C 


RAR 




MOV 


C,A 


DCR 


E 


JZ 


DONE 


MOV 


A.B 


JNC 


MULT1 


ADD 


D 



MULT1: 



DONE: 



RAR 

MOV 
JMP 



INITIALIZE MOST SIGNIFICANT BYTE 

;OF RESULT 

BIT COUNTER 

ROTATE LEAST SIGNIFICANT BIT OF 

MULTIPLIER TO CARRY AND SHIFT 

LOW-ORDER BYTE OF RESULT 

;EXIT IF COMPLETE 



ADD MULTIPLICAND TO HIGH- 
;ORDER BYTE OF RESULT IF BIT 
WAS A ONE 

;CARRY=0 HERE SHIFT HIGH- 
;ORDER BYTE OF RESULT 



B.A 
MULTO 



An analogous procedure is used to divide an unsigned 16-bit number by an unsigned 16-bit number. Here, the 
process involves subtraction rather than addition, and rotate-left instructions instead of rotate-right instructions. 
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The following reentrant program uses the B and C registers to hold the dividend and quotient, and the D and E 
register to held the divisor and remainder. The H and L registers are used to store data temporarily. 



DtV: 



DVO: 



DV1: 



MOV 


A,D 


CM A 




MOV 


D,A 


MOV 


A,E 


CM A 




MOV 


E,A 


INX 


D 


LXI 


H.O 


MV1 


A,17 


PUSH 


H 


DAD 


D 


JNC 


DV1 


XTHL 




POP 


H 


PUSH 


PSW 


MOV 


A.C 


RAL 




MOV 


C,A 


MOV 


A.B 


RAL 




MOV 


B,A 


MOV 


A,L 


RAL 




MOV 


L.A 


MOV 


A.H 


RAL 




MOV 


H.A 


POP 


PSW 


DCR 


A 


INZ 


DVO 



;NEGATE THE DIVISOR 



FOR TWO'S COMPLEMENT 

INITIAL VALUE FOR REMAINDER 

INITIALIZE LOOP COUNTER 

SAVE REMAINDER 

SUBTRACT DIVISOR (ADD NEGATIVE) 

UNDER FLOW, RESTORE HL 



SAVE LOOP COUNTER (A) 
;4 REGISTER LEFT SHIFT 
;WITH CARRY 
;CY->C->B->L->H 



RESTORE LOOP COUNTER (A) 
DECREMENT IT 
KEEP LOOPING 



;POST-DMDE CLEAN UP 

;SHIFT REMAINDER RIGHT AND RETURN IN DE 



MOV 


A,H 


RAR 




MOV 


D,A 


MOV 


AX 


RAR 




MOV 


E,A 


RET 




END 
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MULTI8YTE ADDITION AND SUBTRACTION 

The carry flag and the ADC (add with carry) instructions may be used to add unsigned data quantities of 
arbitrary length. Consider the following addition of two three-byte unsigned hexadecimal numbers: 

32AF8A 
+84BA90 



B76A1A 



To perform this addition, add to the low-order byte using an ADD instruction. ADD sets the carry flag for use 
in subsequent instructions, but does not include the carry flag in the addition. Then use ADC to add to all 
higher order bytes. 



n 

32 

84 



carry = 1 



n 

AF 
BA 

6A 



carry = 1 - 



8A 
90 

-1A 



The following routine will perform this multibyte addition, making these assumptions: 

The E register holds the length of each number to be added (in this case, 3). 

The numbers to be added are stored from low-order byte to high-order byte beginning at memory locations 
FIRST and SECND, respectively, 

The result will be stored from low-order byte to high-order byte beginning at memory location FIRST, replacing 
the original contents of these locations. 



MEMORY 
LOCATION before 



after 



FIRST 

FIRST+1 

FIRSTf2 

SECND 

SECND+1 

SECND+2 



AF 



32 



90 



BA 



84 



■ + 

A 









1A 



6A 



B7 



90 



BA 



84 



carry 
carry 
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The following routine uses an ADC instruction to add the low-order bytes of the operands. This could cause 
the result to be high by one if the carry flag were left set by some previous instruction. This routine avoids 
the problem oy clearing the carry flag with the XRA instruction just before LOOP. 



Label 



MADD: 



LOOP: 



DONE: 



r IRST; 



SECND: 



Code 


Operand ( 


Comment 


LXI 


B, FIRST 


B AND C ADDRESS FIRST 


LXi 


H.SECND 


H AND L ADDRESS SECND 


XRA 


A 


CLEAR CARRY FLAG 


LDAX 


B 


LOAD BYTE OF FIRST 


ADC 


M 


ADD BYTE OF SECND 
WITH CARRY 


5TAX 


B 


STORE RESULT AT FIRST 


DCR 


E 


DONE IF E = 


JZ 


DONE 




INX 


B 


POINT TO NEXT BYTE OF 
FIRST 


INX 


H 


POINT TO NEXT BYTE OF 
SECND 


IMP 


LOOP 


;ADD NEXT TWO BYTES 


DB 


90H 




DB 


OBAH 




DB 


84H 




DB 


8AH 




DB 


OAFH 




DB 


32H 





Since none cf the instructions in the program loop affect the carry flag except ADC, the addition with carry will 
proceed comctly. 

When location DONE is reached, bytes FIRST through FIRST+2 will contain 1A6AB7, which is the sum shown 
at the beginning of this section arranged from low-order to high-order byte. 

In order to t reate a multibyte subtraction routine, it is necessary only to duplicate the muitibyte addition routine 
of this sectic n, changing the ADC instruction to an SBB instruction. The program will then subtract the number 
beginning at SECND from the number beginning at FIRST, placing the result at FIRST, 



DECIMAL ADDITION 

Any 4-bit cfc-ta quantity may be treated as a decimal number as long as it represents one of the decimal digits 
from through 9, and does not contain any of the bit patterns representing the hexadecimal digits A through F. 
In order to preserve this decimal interpretation when performing addition, the value 6 must be added to the 
4-bit quantify whenever the addition produces a result between 10 and 15. This is because each 4-bit data 
quantity can hold 6 more combinations of bits than there are decimal digits. 
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Decimal addition is performed by letting each 8-bit byte represent two 4-bit decimal digits. The bytes are 
summed in the accumulator in standard fashion, and the DAA (decimal adjust accumulator) instruction is then 
used to convert the 8-bit binary result to the correct representation of 2 decimal digits. For multtbyte strings, 
you must perform the decimal adjust before adding the next higher-order bytes. This is because you need the 
carry flag setting from the DAA instruction for adding the higher-order bytes. 

To perform the decimal addition: 

2985 
+4936 

7921 

the process works as follows: 

1. Clear the Carry and add the two lowest-order digits of each number (remember that each 2 
decimal digits are represented by one byte). 

85 = 10000101 B 
36-00110110B 
carry = 



rOjiomoiiB 

\ 



Carry = Auxiliary Carry = 

The accumulator now contains 0BBH. 

2. Perform a DAA operation. Since the rightmost four bits are greater than 9, a 6 is added to the 
accumulator. 

Accumulator = 101 1 101 1 B 
6 011Q B 

11 000001 B 

Since the leftmost bits are greater than 9, a 6 is added to these bits, thus setting the carry flag. 

Accumulator = 11 000001 B 
6 = 0110 B 

^T] 001 00001 B 
Carry flag = 1 
The accumulator now contains 21 H. Store these two digits. 
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Add the next group of two digits: 



29 = 001 01 001 B 
49 = 01 001 001 B 



carry 



r olomooiiB 

\ 

Carry = Auxiliary Carry = 1 

The accumulator now contains 73H. 

* ■, Perform a DAA operation. Since the auxiliary carry flag is set, 6 is added to the accumulator. 

Accumuiator = 01 11 001 IB 
6 0110 B 

^gonnooiB 

Carry flag = 

Since the leftmost 4 bits are less than 10 and the carry flag is reset, no further action occurs. 

Thus, the correct decimal result 7921 is generated in two bytes. 

A routine wiich adds decimal numbers, then, is exactly analogous to the multibyte addition routine MADD of 
the last sect on, and may be produced by inserting the instruction DAA after the ADC M instruction of that 
example. 

Each iteration of the program loop will add two decimal digits (one byte) of the numbers. 

DECIMAL SUBTRACTION 

Decimal subtraction is considerably more complicated than decimal addition. In general, the process consists of 
generating tie tens complement of the subtrahend digit, and then adding the result to the minuend digit. For 
example, to subtract 34 from 56, form the tens complement of 34 (99-34=65+1=66). Then, 56+66=122. By 
truncating cff the carry out of the high order digit, we get 22, the correct result. 

The problem of handling borrows arises in multibyte decimal subtractions. When no borrow occurs from a sub- 
tract, you want to use the tens complement of the subtrahend for the next operation. If a borrow does occur, 
you want to use the nines complement of the subtrahend. 

Notice that the meaning of the carry flag is inverted because you are dealing with complemented data. Thus, a 
one bit in tie carry flag indicates no borrow; a zero bit in the carry flag indicates a borrow. This inverted carry 
flag setting :an be used in an add operation to form either the nines or tens complement of the subtrahend. 



6-14 



Chapter 6. Programming Techniques 

The detailed procedure for subtracting multi-digit decimal numbers is as follows: 

1. Set the carry flag ~ 1 to indicate no borrow. 

2. Load the accumulator with 99H, representing the number 99 decimal. 

3. Add zero to the accumulator with carry, producing either 99H or 9AH, and resetting the 
carry flag. 

4. Subtract the subtrahend digits from the accumulator, producing either the nines or tens 
complement. 

5. Add the minuend digits to the accumulator. 

6. Use the DAA instruction to make sure the result in the accumulator is in decimal format, and 
to indicate a borrow in the carry flag if one occurred. 

7. If there are more digits to subtract, go to step 2. Otherwise, stop. 
Exampie: 

Perform the decimal subtraction: 

4358D 
-1362D 

2996D 

1. Set carry = 1 . 

2. Load accumulator with 99H. 

3. Add zero with carry to the accumulator, producing 9AH. 

Accumulator = 1 0011 001 B 
= O00OOO00B 

Carry = 1 

1001 101 OB = 9AH 

4. Subtract the subtrahend digits 62 from the accumulator. 

Accumulator = 1001 101 0B 
62 = 1001111 B 

UoomoooB 
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5. Add the minuend digits 58 to the accumulator. 

Accumulator = 00111000B 
58 = 01Q11000 B 

J510010000B = 90H 

\ 

Carry = Auxiliary Carry - 1 

6. DAA converts accumulator to 96 (since Auxiliary Carry = 1) and leaves carry flag = 
indicating that a borrow occurred. 

7. Load accumulator with 99H. 

8. Add zero with carry to accumulator, leaving accumulator = 99H. 

9. Subtract the subtrahend digits 13 from the accumulator. 
Accumulator = 10011001B 

T3 = nionoi B 

J 1000011 OB 

10. Add the minuend digits 43 to the accumulator. 

Accumulator = 1000011 0B 
43 - 01 00001 1 B 

-,2 1 1001 001 B = C9H 

^^ \ 

Carry = Auxiliary Carry = 

1 1 DAA converts accumulator to 29 and sets the carry flag = 1 , indicating no borrow occurred. 
Therefore, the result of subtracting 1362 from 4358 is 2996. 
The following subroutine will subtract one 16-digit decimal number from another using the following assumptions: 
The minuend is stored least significant (2) digits first beginning at location MINU. 
The subtraheid is stored least significant (2) digits first beginning at location SBTRA. 
The result will be stored least significant (2) digits first, replacing the minuend. 
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Label 
DSUB: 



LOOP: 



Code 

LXI 
LXI 

MVi 



STC 

MVI 

AC I 
SUB 

XCHG 



Operand 

D.MiNU 
H.SBTRA 



A.99H 


M 



DONE: 



ADD 


M 


DAA 




MOV 


M.A 


XCHG 




DCR 


C 


)Z 


DONE 


INX 


D 


INX 


H 


JMP 


LOOP 


NOP 





Comment 

D AND E ADDRESS MINUEND 
H AND L ADDRESS SUBTRA- 
HEND 

EACH LOOP SUBTRACTS 2 
DIGITS (ONE BYTE), 
THEREFORE PROGRAM WILL 
SUBTRACT 16 DIGITS. 
;SET CARRY INDICATING 
NO BORROW 
LOAD ACCUMULATOR 
;WITH 99H. 

ADD ZERO WITH CARRY 
PRODUCE COMPLEMENT 
;OF SUBTRAHEND 
SWITCH D AND E WITH 
H AND L 
ADD MINUEND 
;DECIMAL ADJUST 
ACCUMULATOR 
STORE RESULT 
RESW1TCH D AND E 
;WITH H AND L 
DONE IF C = 

ADDRESS NEXT BYTE 

;OF MINUEND 

ADDRESS NEXT BYTE 

;OF SUBTRAHEND 

GET NEXT 2 DECIMAL DIGITS 
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INTERRUPT CONCEPTS 

The following is a general description of interrupt handling and applies to both the 8080 and 8085 processors. 
However, the 8085 processor has some additional hardware features for interrupt handling. For more infor- 
mation on these features, see the description of the 8085 processor in Chapter 1 and the descriptions of the 
RIM, SIM, and RST instructions in Chapter 3. 

Often, events occur external to the central processing unit which require immediate action by the CPU. For 
example, suppose a device is sending a string of 80 characters to the CPU, one at a time, at fixed intervals. 
There are two ways to handle such a situation: 

A. A program could be written which accepts the first character, waits until the next character is 
ready (e.g., executes a timeout by incrementing a sufficiently large counter), then accepts the 
next character, and proceeds in this fashion until the entire 80 character string has been received. 

This method is referred to as programmed Input/Output. 

B. The device controller could interrupt the CPU when a character is ready to be input, forcing a 
branch from the executing program to a special interrupt service routine. 

The interrupt sequence may be illustrated as follows: 

INTERRUPT 



Normai 

Program 

Execution 




Interrupt Service 
Routine 
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The 8080 cor tains a bit named !NTE which may be set or reset by the instructions E! and Dl described in 
Chapter 3. Whenever 1NTE is equal to 0, the entire interrupt handling system is disabled, and no interrupts 
wilt be accepted, 

When the 8010 recognizes an interrupt request from an external device, the following actions occur: 

1. The instruction currently being executed is completed. 

2. The interrupt enable bit, INTE, is reset = 0, 

3. The interrupting device supplies, via hardware, one instruction which the CPU executes. This 
instruction does not appear anywhere in memory, and the programmer has no control over it, 
since it is a function of the interrupting device's controller design. The program counter is not 
incremented before this instruction. 

The instruction supplied by the interrupting device is normally an RST instruction (see Chapter 3), since this 
is an efficient one byte call to one of 8 eight-byte subroutines located in the first 64 words of memory, For 
instance, the device may supply the instruction: 

RST OH 

with each input interrupt. Then the subroutine which processes data transmitted from the device to the CPU 
will be called into execution via an eight-byte instruction sequence at memory locations 0000H to 0007H. 

A digital inpi t device may supply the instruction: 

RST 1H 

Then the sub'outine that processes the digital input signals will be called via a sequence of instructions 
occupying memory locations 0008H to 0OOFH, 



Device L a' 
suppiie, RST OH 



Transfers 
control to 



-*-0000 
0007 



Beginning of 
subroutine for 
device V 



Device V 
supplie. RST 1H 



Transfers 
control to 



-*- 0008 
000 F 



Beginning of 
subroutine for 
device V 
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Device V 
supplies RST 7H 



Transfers 
control to 



0038 



003 F 



Beginning of 
subroutine for 
device V 



Note that any of these 8-byte subroutines may in turn call longer subroutines to process the interrupt, if 
necessary. 

Any device may supply an RST instruction (and indeed may supply any one-byte 8080 instruction), 

The following is an example of an Interrupt sequence: 



ARBITRARY 
MEMORY ADDRESS 

3C0B 
—*» 3C0C 



INSTRUCTION 

MOV C } B ^ 
MOV E.A 




0000 



instruction V 
Instruction 2 
RET 



Interrupt from Device 1 



Device 1 supplies 

RST OH 
Program Counter = 
3C0C pushed onto 
the stack. 

Control transferred to 
to 0000 



Stack popped into 
program counter 



Device 1 signals an interrupt as the CPU is executing the instruction at 3C0B. This instruction is completed. 
The program counter remains set to 3C0C, and the instruction RST OH supplied by device 1 is executed. 
Since this is a call to location zero, 3C0C is pushed onto the stack and program control is transferred to 
location OOOOH. (This subroutine may perform jumps, calls, or any other operation.) When the RETURN is 
executed, address 3C0C is popped off the stack and replaces the contents of the program counter, causing 
execution to continue at this point. 
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WRITING INTERRUPT SUBROUTINES 

In general, an\ registers or condition bits changed by an interrupt subroutine must be restored before returning 
to the interrupted program, or errors will occur. 

For example, uppose a program is interrupted just prior to the instruction: 

JC LOG 

and the carry ?it equals 1 , If the interrupt subroutine happens to reset the carry bit before returning to the 
interrupted program, the jump to LOC which should have occurred will not, causing the interrupted program 
to produce erroneous results. 

Like any othe: subroutine then, any interrupt subroutine should save at least the condition bits and restore them 
before performing a RETURN operation. (The obvious and most convenient way to do this is to save the data 
in the stack, using PUSH and POP operations.) 

Further, the it terrupt enable system is automatically disabled whenever an interrupt is acknowledged. Except in 
special cases, therefore, an interrupt subroutine should include an El instruction somewhere to permit detection 
and handling cf future interrupts. One instruction after an El is executed, the interrupt subroutine may itself be 
interrupted. T lis process may continue to any level, but as long as all pertinent data are saved and restored, 
correct progra n execution will continue automatically, 

A typical inteirupt subroutine, then, could appear as follows: 

Code Operand Comment 



PUSH PSW 

EI 



SAVE CONDITION BITS AND ACCUMULATOR 
RE-ENABLE INTERRUPTS 

PERFORM NECESSARY ACTIONS TO SERVICE 
THE INTERRUPT 



POP PSW ;RESTORE MACHINE STATUS 

RET ;RETURN TO INTERRUPTED PROGRAM 
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APPENDIX A. INSTRUCTION SUMMARY 

This appendix summarizes the bit patterns and number of time states associated with every 8080 CPU 
instruction. The instructions are listed in both mnemonic (alphabetical) and operation code (numerical) 
sequence. 

When using this summary, note the following symbology, 

DDD represents a destination register. SSS represents a source register. Both DDD and SSS are interpreted 
as follows: 



DDD or SSS 



Interpretation 



000 
001 
010 

on 

100 
101 
110 

in 



Register B 

Register C 

Register D 

Register E 

Register H 

Register L 

A memory register or stack pointer or PSW 

(flags + accumulator) 

The accumulator 



Instruction execution time equals number of time periods multiplied by the duration of a time period. 

A time period may vary from 480 nanoseconds to 2 microseconds on the 8080 or 320 nanoseconds to 2 
microseconds on the 8085. Where two numbers of time periods are shown (eq.5/1 1), it means that the 
smaller number of time periods is required if a condition is not met, and the larger number of time periods 
is required if the condition is met. 



MNEMONIC 


D 7 
















NUMBER OF TIME PERIODS 


D 6 


D 5 


D 4 


D 3 


D 2 


D 1 


D o 
























8080 


8085 


CALL 












1 







1 


17 


18 


CC 









1 


1 










11/17 


9/18 


CNC 









1 













11/17 


9/18 


CZ 












1 










11/17 


9/18 


CNZ 























11/17 


9/18 


CP 






1 


1 













11/17 


9/18 


CM 






1 


1 


1 










11/17 


9/18 


CPE 






1 





1 










11/17 


9/17 


CPO 






1 
















11/17 


9/18 


RET 












1 








1 


10 


10 


RC 









1 


1 











5/11 


6/12 


RNC 









1 














5/11 


6/12 


RZ 












1 











5/11 


6/12 
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MNEMONIC 


D 7 


D 6 


D 5 


D 4 


D 3 


D 2 


D 1 


D o 


NUMBER OF TIME PERIODS 


8080 


8085 


RNZ 
























5/11 


6/12 


RP 






1 


1 














5/11 


6/12 


RM 






1 


1 


1 











5/11 


6/12 


RPE 






1 





1 











5/11 


6/12 


RPO 






1 

















5/11 


6/12 


RST 






A 


A 


A 


1 


1 




11 


12 


IN 









1 


1 





1 




10 


10 


OUT 









1 








1 




10 


10 


LXi B 

























10 


10 


LXi D 











1 













10 


10 


LXi H 








1 
















10 


10 


LXI SP 








1 


1 













10 


10 


PUSH B 


1 


1 











1 







11 


12 


PUSH D 


1 


1 





1 





1 







11 


12 


PUSH H 


1 


1 


1 








1 







11 


12 


PUSH PSW 


1 


1 


1 


1 





1 







11 


12 


POP B 


1 


1 



















10 


10 


POP D 


1 


1 





1 













10 


10 


POP H 


1 


1 


1 
















10 


10 


POP PSW 


1 


1 


1 


1 













10 


10 


STA 








1 


1 








1 





13 


13 


LDA 








1 


1 


1 





1 





13 


13 


XCHG 


1 


1 


1 





1 





1 




4 


4 


XTHL 


1 


1 


1 











1 




18 


16 


SPHL 


1 


1 


1 


1 


1 










5 


6 


PCHL 


1 


1 


1 





1 










5 


6 


DAD B 














1 










10 


10 


DAD D 











1 


1 










10 


10 


DAD H 








1 





1 










10 


10 


DADSP 








1 


1 


1 










10 


10 


STAX B 




















1 





7 


7 


STAX D 











1 








1 





7 


7 


LDAX B 














1 





1 





7 


7 


LDAX D 











1 


1 





1 





7 


7 


INX B 




















1 


1 


5 


6 


INX D 











1 








1 


1 


5 


6 


INX H 








1 











1 


1 


5 


6 


INX SP 








1 


1 








1 


1 


5 


6 


MOV r-\ f r 2 





1 


D 


D 


D 


s 


s 


s 


5 


4 


MOV M,r 





1 


1 


1 





s 


s 


s 


7 


7 


MOV r.M 





1 


D 


D 


D 




1 





7 


7 


HLT 





1 


1 


1 







1 





7 


5 


MVI r 








D 


D 


D 




1 





7 


7 


MVi M 








1 


1 







1 





10 


10 


INR 








D 


D 


D 










5 


4 


DCR 








D 


D 


D 







1 


5 


4 
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NUMBER OF TIME PERIODS 


MNEMONIC 


D 7 


D 6 


D 5 


D 4 


D 3 


D 2 


D 1 


D o 


























8080 


8085 


INR A 








1 


1 


1 


1 








5 


4 


DCR A 








1 


1 


1 


1 





1 


5 


4 


INR M 








1 


1 





1 








10 


10 


DCR M 








1 


1 





1 





1 


10 


10 


ADD r 
















s 


s 


s 


4 


4 


ADCr 













1 


s 


s 


s 


4 


4 


SUB r 










1 





s 


s 


5 


4 


4 


SBBr 










1 


1 


s 


s 


s 


4 


4 


AND r 







1 








s 


s 


s 


4 


4 


XRA r 







1 





1 


s 


s 


s 


4 


4 


ORA r 







1 


1 





s 


s 


s 


4 


4 


CMPr 







1 


1 


1 


s 


s 


5 


4 


4 


ADD M 























7 


7 


ADC M 













1 









7 


7 


SUB M 










1 












7 


7 


SBB M 










1 


1 









7 


7 


AND M 







1 















7 


7 


XRA M 







1 





1 









7 


7 


ORA M 







1 


1 












7 


7 


CMP M 







1 


1 


1 









7 


7 


ADI 






















7 


7 


AC I 












1 









7 


7 


SUi 









1 












7 


7 


SB! 









1 


1 









7 


7 


AN I 






1 















7 


7 


XR! 






1 





1 









7 


7 


ORI 






1 


1 












7 


7 


CPi 






1 


1 


1 









7 


7 


RLC 























4 


4 


RRC 














1 








4 


4 


RAL 











1 











4 


4 


RAR 











1 


1 








4 


4 


JMP 






















10 


10 


JC 









1 


1 










10 


7/10 


JNC 









1 













10 


7/10 


JZ 












1 










10 


7/10 


JNZ 























10 


7/10 


JP 






1 


1 













10 


7/10 


JM 






1 


1 


1 










10 


7/10 


JPE 






1 





1 










10 


7/10 


jPO 






1 
















10 


7/10 


DCX B 














1 







1 


5 


6 


PCX D 











1 


1 







1 


5 


6 


DCX H 








1 





1 







1 


5 


6 


DCXSP 








1 


1 


1 







1 


5 


6 
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NUMBER OF TIME PERIODS 


MNEMONIC 


D 7 


D 6 


D 5 


D 4 


D 3 


D 2 


D l 


D o 


























8080 


8085 


CMA 













1 


1 


1 


1 


4 


4 


STC 










1 





1 


1 


1 


4 


4 


CMC 










1 


1 


1 


1 


1 


4 


4 


DAA 
















1 


1 


1 


4 


4 


SHLD 



















1 





16 


16 


LHLD 













1 





1 





16 


16 


RIM 

























- 


4 


SIM 










1 














_ 


4 


El 


1 


1 




1 


1 





] 


1 


4 


4 


Dl 


1 


1 




1 








1 


1 


4 


4 


NOP 


























4 


4 
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The following is a summary of the instruction set: 
8080/85 CPU INSTRUCTIONS IN OPERATION CODE SEQUENCE 



OP 




OP 






OP 






CODE 


MNEMONIC 


CODE 


MNEMONIC 


CODE 


MNEMONIC 


00 


NOP 


2B 


DCX 


H 


56 


MOV 


DM 


01 


LXi B,D16 


2C 


INR 


L 


57 


MOV 


DA 


02 


ST AX B 


2D 


DCR 


L 


58 


MOV 


E.B 


03 


1NX B 


2E 


MVI 


L,D8 


59 


MOV 


E.C 


04 


INR B 


2F 


CMA 




5A 


MOV 


E.D 


05 


DCR B 


30 


SIM 




5B 


MOV 


E.E 


06 


MVI B,D8 


31 


LXI 


SPD16 


5C 


MOV 


E,H 


07 


RLC 


32 


STA 


Adr 


5D 


MOV 


E,L 


08 


- 


33 


iNX 


SP 


5E 


MOV 


EM 


09 


DAD B 


34 


INR 


M 


5F 


MOV 


EA 


0A 


LDAXB 


35 


DCR 


M 


60 


MOV 


H.B 


0B 


DCX B 


36 


MVI 


M.D8 


61 


MOV 


H.C 


OC 


INR C 


37 


STC 




62 


MOV 


H,D 


0D 


DCR C 


38 


— 




63 


MOV 


H.E 


0E 


MVI C,D8 


39 


DAD 


SP 


64 


MOV 


H.H 


OF 


RRC 


3A 


LDA 


Adr 


65 


MOV 


H,L 


10 


— 


3B 


DCX SP 


66 


MOV 


HM 


11 


LXI D.D16 


3C 


INR 


A 


67 


MOV 


HA 


12 


STAX D 


3D 


DCR 


A 


68 


MOV 


L.B 


13 


INX D 


3E 


MVI 


A,D8 


69 


MOV 


L.C 


14 


INR D 


3F 


CMC 




6A 


MOV 


L.D 


15 


DCR D 


40 


MOV 


B,B 


6B 


MOV 


L,E 


16 


MVI D.D8 


41 


MOV 


B,C 


6C 


MOV 


L,H 


17 


RAL 


42 


MOV 


B,D 


6D 


MOV 


L.L 


18 





43 


MOV 


B.E 


6E 


MOV 


LM 


19 


DAD D 


44 


MOV 


B,H 


6F 


MOV 


LA 


1A 


LDAXD 


45 


MOV 


B,L 


70 


MOV 


M,B 


IB 


DCX D 


46 


MOV 


B,M 


71 


MOV 


M,C 


1C 


INR E 


47 


MOV 


B t A 


72 


MOV 


M,D 


ID 


DRC E 


48 


MOV 


C,B 


73 


MOV 


M,E 


IE 


MVI E.D8 


49 


MOV 


C.C 


74 


MOV 


M ? H 


IF 


RAR 


4A 


MOV 


CD 


75 


MOV 


M,L 


20 


RIM 


4B 


MOV 


C.E 


76 


HLT 




21 


LXI H.D16 


4C 


MOV 


C,H 


77 


MOV 


MA 


22 


SHLD Adr 


4D 


MOV 


C T L 


78 


MOV 


A.B 


23 


INX H 


4E 


MOV 


CM 


79 


MOV 


A,C 


24 


INR H 


4F 


MOV 


CA 


7A 


MOV 


AX> 


25 


DCR H 


50 


MOV 


D,B 


7B 


MOV 


A ? E 


26 


MVI H.D8 


51 


MOV 


D,C 


7C 


MOV 


A,H 


27 


DAA 


52 


MOV 


D.D 


7D 


MOV 


A,L 


28 


__ 


53 


MOV 


D.E 


7E 


MOV 


AM 


29 


DAD H 


54 


MOV 


D.H 


7F 


MOV 


AA 


2A 


LHLD Adr 


55 


MOV 


D.L 


80 


ADD 


B 



OP 






OP 






OP 




CODE 


MNEMONIC 


CODE 


MNEMONIC 


CODE 


MNEMONIC 


81 


ADD 


C 


AC 


XRA 


H 


D7 


RST 2 


82 


ADD 


D 


AD 


XRA 


L 


D8 


RC 


83 


ADD 


E 


AE 


XRA 


M 


D9 


- 


84 


ADD 


H 


AF 


XRA 


A 


DA 


jC Adr 


85 


ADD 


L 


B0 


ORA 


B 


DB 


IN D8 


86 


ADD 


M 


B1 


ORA 


C 


DC 


CC Adr 


87 


ADD 


A 


B2 


ORA 


D 


DD 


_ 


88 


ADC 


B 


B3 


ORA 


E 


DE 


SB I D8 


89 


ADC 


C 


B4 


ORA 


H 


DF 


RST 3 


8A 


ADC 


D 


B5 


ORA 


L 


E0 


RPO 


SB 


ADC 


E 


B6 


ORA 


M 


El 


POP H 


8C 


ADC 


H 


B7 


ORA 


A 


E2 


JPO Adr 


8D 


ADC 


L 


B8 


CMP 


B 


E3 


XTHL 


8E 


ADC 


M 


B9 


CMP 


C 


E4 


CPO Adr 


8F 


ADC 


A 


BA 


CMP 


D 


E5 


PUSH H 


8G 


SUB 


B 


BB 


CMP 


E 


E6 


ANI D8 


91 


SUB 


C 


BC 


CMP 


H 


E7 


RST 4 


92 


SUB 


D 


BD 


CMP 


L 


E8 


RPE 


93 


SUB 


E 


BE 


CMP 


M 


E9 


PCHL 


94 


SUB 


H 


BF 


CMP 


A 


EA 


■JPE Adr 


95 


SUB 


L 


CO 


RNZ 




EB 


XCHG 


96 


SUB 


M 


CI 


POP 


B 


EC 


CPE Adr 


97 


SUB 


A 


C2 


jNZ 


Adr 


ED 





98 


SBB 


B 


C3 


IMP 


Adr 


EE 


XRI D8 


99 


SBB 


C 


C4 


CNZ 


Adr 


EF 


RST 5 


9A 


SBB 


D 


C5 


PUSH B 


F0 


RP 


9B 


SBB 


E 


C6 


ADI 


D8 


F1 


POP PSW 


9C 


SBB 


H 


C7 


RST 





F2 


|P Adr 


9D 


SBB 


L 


C8 


RZ 




F3 


Dl 


9E 


SBB 


M 


C9 


RET 


Adr 


F4 


CP Adr 


9F 


SBB 


A 


CA 


JZ 




F5 


PUSH PSW 


A0 


ANA 


B 


CB 


— 




F6 


ORI D8 


A1 


ANA 


C 


CC 


cz 


Adr 


F7 


RST 6 


A2 


ANA 


D 


CD 


CALL 


Adr 


F8 


RM 


A3 


ANA 


E 


CE 


ACI 


D8 


F9 


SPHL 


A4 


ANA 


H 


CF 


RST 


1 


FA 


JM Adr 


AS 


ANA 


L 


DO 


RNC 




FB 


El 


A6 


ANA 


M 


D1 


POP 


D 


FC 


CM Adr 


A7 


ANA 


A 


D2 


INC 


Adr 


FD 


— 


A8 


XRA 


B 


D3 


OUT 


D8 


FE 


CPI D8 


A9 


XRA 


C 


D4 


CNC 


Adr 


FF 


RST 7 


AA 


XRA 


D 


D5 


PUSH 


D 






AB 


XRA 


E 


D6 


SUI 


D8 







D8 - constant, or (ogical/anthmetic expression that evaluates D16 

to an 8 fait data quantity. 
Adr = 16-bit address 



constant, or logical/arithmetic 
to a 1 6 bit data quantity 
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instruction Set Guide 



The following is t summary of the instruction set: 



ADD 

ADC 

SUB 

S3B 

ANA 

XRA 

CRA 

CMP 



\ REGMg 



ADI 
AC! 
SUi 
SBI 
AN! 
XRi 
OR! 
CP! 



> D 8 



RLC RAL RRC 
RAR CMA DAA 

INR' 

DCRf 



MOV REGMg,REGMgQ 

i r 

LXIREG 16f D 16 |-= 



-(accumulator 



REGMc 



FLAGS 



1STC CMC 

JlNX^I 



HIGH LOW 

DCX|>REG 16 SPHL H STACK j POINflF 



]^°J PCH Lp> | PROGRAM ' COUNTER^ - RST 



XCHG 



-XTHL — | 



JMP 

jC jNC 

JZ jNZ 

jP JM 

jPE jPO 



CALL 

CC CNC N 

CZ CNZ 

^16 CP CM 

CPE CPO 



RET 

RC RNC1 

RZ RNZ[ 

16 RP RM f ,% 1( 

RPE RPOj 



LDAX \ BC.DE 
ST AX J 



LDA) 
STAJ 



16 



MVi D g 

MOV REGMg,REGI/1 g 

CODE 



LHLDl 
STHDJ A 16 



MEMORY 



STACK 



INP n 



1 

OUT P 



INPUT 
PORTS 



OUTPUT 
PORTS 



PUSH 1 
' POP j 



> B.D.H.PSW 



CONTROL 
INSTRUCTIONS 

RST 

NOP 

HLT 

El 

Dl 

SIM 1 8085 ONLY 
RIMJ 



MEANING 



REGM S 



A 16 

P 8 
REG 

D 16 



16 



The operand may specify one of the 8-bit registers A,B,C,D,E,H, or L or M (a memory 

reference via the 16-bit address in the H and L registers). The MOV instruction, which 

calls for two operands, can specify M for only one of its operands. 

Designates 8-bit immediate operand. 

Designates a 16-bit address. 

Designates an 8-bit port number. 

Designates a 16-bit register pair (B&C,D&E.H&L,or SP). 

Designates a 16 -bit immediate operand. 



ALL MNEMONICS © 1074, 1975, 7976, 1977 INTEL CORPORATION 



A-6 



APPENDIX B. ASSEMBLER DIRECTIVE SUMMARY 



Assembler directives are summarized alphabetically in this appendix. The following terms are used to describe 
the contents of directive fields. 



NOTATION 



Term 
Expression 

List 

Name 

Null 

Opiab 

Parameter 

String 
Text 



interpretation 

Numerical expression evaluated during assembly; must evaluate 
to 8 or 16 bits depending on directive issued. 

Series of symbolic values or expressions, separated by commas. 

Symbol name terminated by a space. 

Field must be empty or an error results. 

Optional label; must be terminated by a colon. 

Dummy parameters are symbols holding the place of actual 
parameters (symbolic values or expressions) specified elsewhere 
in the program. 

Series of any ASCI! characters, surrounded by single quote marks. 
Single quote within string is shown as two consecutive single quotes. 

Series of ASCII characters. 



Macro definitions and calls allow the use of the special characters listed below. 



Character 
& 

<> 



Funct/on 

Ampersand. Used to concatenate symbols. 

Angle brackets. Used to delimit text, such as lists, that contain 
other delimiters. 

Double semicolon. Used before a comment in a macro definition 
to prevent inclusion of the comment in each macro expansion. 

Exclamation point (escape character). Placed before a delimiter 
to be passed as a literal in an actual parameter. To pass a literal 
exclamation point, issue '!!.' 

Percent sign. Precedes actual parameters to be evaluated immediately 
when the macro is called. 
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SUMMARY OF DIRECTIVES 






FORMA T 




Label 


Opcode 


Operand(s) 


oplab: 


3B 


exp(s) or string(s) 


oplab: 


DS 


expression 


oplab: 


DW 


exp(s) or string(s) 



FUNCTION 



Define 8-bit data byte(s). Expressions must evaluate 
to one byte. 

Reserve data storage area of specified length. 

Define 16-bit data word(s). Strings limited to 1-2 
characters. 



oplab: 



oplab: 



oplab: 



oplab: 



oplab: 



ELSE 



END 



expression 



ENDIF 


null 


EQU 


expression 


IF 


expression 


DRG 


expression 


;et 


expression 



Conditional assembly. Code between ELSE and 
ENDIF directives is assembled if expression in IF 
clause is FALSE. (See IF.) 

Terminate assembler pass. Must be last statement of 
program. Program execution starts at 'exp,' if present; 
otherwise, at location 0. 

Terminate conditional assembly block. 

Define symbol 'name' with value 'exp.' Symbol is not 
redefinable. 

Assemble code between IF and following ELSE or 
ENDIF directive if 'exp' is true. 

Set location counter to 'expression.' 

Define symbol 'name 1 with value 'expression.* 
Symbol can be redefined. 



MACRO DIRECTIVES 





FORMA T 




Label 


( opcode 


Operand(s) 


null 


LNDM 


null 


oplab: 


LXITM 


null 


oplab: 


IRP 


dummy param,<list> 



FUNCTION 

Terminate macro definition. 

Alternate terminator of macro definition. (See ENDM.) 

Repeat instruction sequence, substituting one character 
form 'fist' for 'dummy param' in each iteration. 



ALL MNEMONICS©1974 t 1975, 1976, 1977 INTEL CORPORATION 



8-2 



Appendix B. Assembler Directive Summary 



FORMAT 
Label Opcode Operand(s) 

oplab: IRPC dummy param.text 



null 



LOCAL label narne(s) 



name MACRO dummy param(s) 



FUNCTION 



Repeat instruction sequence, substituting one 
character from 'text' for 'dummy param' in each 
iteration. 

Specify iabel(s) in macro definition to have local 
scope. 

Define macro 'name' and dummy parameter(s) to be 
used in macro definition. 



oplab: REPT expression 



Repeat REPT block 'expression' times. 



RELOCATION DIRECTIVES 



FORMA T 
Label Opcode Operand(s) 

oplab: ASEG null 



oplab: 



oplab: 



CSEG boundary specification 



oplab: DSEG boundary specification 



EXTRN name(s) 



FUNCTION 



Assemble subsequent instructions and data in the 
absolute mode. 

Assemble subsequent instructions and data in the 
relocatable mode using the code location counter. 

Assemble subsequent instructions and data in the 
relocatable mode using the data location counter. 

Identify symbols used in this program module but 
defined in a different module. 



oplab: NAME module— name 

oplab: PUBLIC name(s) 



Assigns a name to the program module. 

Identify symbols defined in this module that are to 
be available to other modules. 



oplab: 



STKLN expression 



Specify the number of bytes to be reserved for the 
stack for this module. 
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The 8080 and 8085 use 
(parity bit) always reset 



ASCII CODES 

the seven-bit ASCII code, with the high-order eighth bit 



GRAPHIC OR 


ASCII 


CONTROL 


(HEXADECIMAL) 


EMUL 


00 


SOH 


01 


STX 


02 


ETX 


03 


EOT 


04 


ENQ 


05 


ACK 


06 


BEL 


07 


BS 


08 


HT 


09 


LF 


0A 


VT 


OB 


FF 


OC 


CR 


OD 


SO 


OE 


Si 


OF 


OLE 


10 


DC1 (X-ON) 


11 


DC2 (TAPE) 


12 


DC3 (X-OFF) 


13 


DC4 (TAF& 


14 


IMAK 


15 


SYN 


16 


ETB 


17 


CAN 


18 


EM 


19 


SUB 


1A 


ESC 


1B 


FS 


1C 


GS 


1D 


RS 


1E 


US 


IF 


SP 


20 


! 


21 


" 


22 


# 


23 


$ 


24 


% 


25 


& 


26 




27 


( 


28 


) 


29 


* 


2A 



GRAPHIC OR 


ASCII 


CONTROL 


(HEXADECIMAL) 


+ 


2B 




2C 


_ 


2D 




2E 


/ 


2F 





30 


1 


31 


2 


32 


3 


33 


4 


34 


5 


35 


6 


36 


7 


37 


8 


38 


9 


39 




3A 




3B 


< 


3C 


= 


3D 


> 


3E 


? 


3F 


@ 


40 


A 


41 


B 


42 


C 


43 


D 


44 


E 


45 


F 


46 


G 


47 


H 


48 


I 


49 


J 


4A 


K 


4B 


L 


4C 


M 


4D 


N 


4E 





4F 


P 


50 


Q 


51 


R 


52 


S 


53 


T 


54 


U 


55 



GRAPHIC OR 


ASCII 


CONTROL (HEXADECIMAL) 


V 


56 


W 


57 


X 


58 


Y 


59 


z 


5A 


t 


58 


\ 


5C 


I 


5D 


Aft) 


5E 


-M 


5F 


' 


60 


a 


61 


b 


62 


c 


63 


d 


64 


e 


65 


f 


66 


9 


67 


h 


68 


i 


69 


i 


6A 


k 


6B 


i 


6C 


m 


6D 


n 


6E 





6F 


P 


70 


q 


71 


r 


72 


s 


73 


t 


74 


u 


75 


V 


76 


w 


77 


X 


78 


y 


79 


z 


7A 




7B 


I 


7C 


} (ALT MODE) 


7D 


^ 


7E 


DEL (RUB OUT) 


7F 
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Appendix D. Binary-Deci nai-Hexadecimal Conversion Tables 

POWERS OF TWO 

2 n n 2" 

1 1.0 

2 1 0.5 
4 2 0.25 
8 3 0.125 

16 4 0.062 5 

32 5 0.031 25 

64 6 0.015 625 

128 7 0.007 812 5 

256 8 0.003 906 25 

512 9 0.001 953 125 

1 024 10 0.000 976 562 5 

2 348 11 0.000 488 281 25 

4 096 12 0.000 244 140 625 

8 192 13 0.000 122 070 312 5 

16 384 14 0.000 061 035 156 25 

32 768 15 0.000 030 517 578 125 

65 536 16 0.000 015 258 789 062 5 

131 372 17 0.000 007 629 394 531 25 

262 144 18 0.000 003 814 697 265 625 

524 288 19 0.000 001 907 348 632 812 5 

1 048 576 20 0.000 000 953 674 316 406 25 

2 097 152 21 0.000 000 476 837 158 203 125 

4 194 304 22 0.000 000 238 418 579 101 562 5 
8 388 308 23 0.000 000 119 209 289 550 781 25 

16 ??? 216 24 0.000 000 059 604 644 775 390 625 

33 554 432 25 0.000 000 029 802 322 387 695 312 5 

67 108 364 26 0.000 000 014 901 161 193 847 656 25 

134 21? 728 27 0.000 000 007 450 580 596 923 828 125 

268 435 456 28 0.000 000 003 725 290 298 461 914 062 5 

536 870 912 29 0.000 000 001 862 645 149 230 957 031 25 

1 073 741 324 30 0.000 000 000 931 322 574 615 478 515 625 

2 147 483 548 31 0.000 000 000 465 661 287 307 739 257 812 5 

4 294 967 296 32 0.000 000 000 232 830 643 653 869 628 906 25 

8 589 934 592 33 0.000 000 000 116 415 321 826 934 814 453 125 

17 179 869 184 34 0.000 000 000 058 207 660 913 467 407 226 562 5 

34 359 738 368 35 0.000 000 000 029 103 830 456 733 703 613 281 25 

68 719 476 736 36 0.000 000 000 014 551 915 228 366 851 806 640 625 

137 438 953 472 37 0.000 000 000 007 275 957 614 183 425 903 320 312 5 

274 877 906 944 38 0.000 000 000 003 637 978 807 091 712 951 660 156 25 

549 755 813 388 39 0.000 000 000 001 818 989 403 545 856 475 830 078 125 

1 099 511 62? ?76 40 0.000 000 000 000 909 494 701 772 928 237 915 039 062 5 

2 199 023 255 552 41 0.000 000 000 000 454 747 350 886 464 118 957 519 531 25 
4 398 046 511 104 42 0.000 000 000 000 22? 373 675 443 232 059 478 759 765 625 

8 796 093 022 208 43 0.000 000 000 000 113 686 837 721 616 029 739 379 882 812 5 

17 592 186 044 416 44 0.000 000 000 000 056 843 418 860 808 014 869 689 941 406 25 

35 184 372 088 832 45 0.000 000 000 000 028 421 709 430 404 007 434 844 970 703 125 

70 368 744 17? 564 46 0.000 000 000 000 014 210 854 715 202 003 717 422 485 351 562 5 

140 737 488 355 328 47 0.000 000 000 000 007 105 427 357 601 001 858 711 242 675 781 25 

281 474 976 710 656 48 0.000 000 000 000 003 552 713 678 800 500 929 355 621 337 890 625 

562 949 953 421 312 49 0.000 000 000 000 001 776 356 839 400 250 464 67? 810 668 945 312 5 

1 125 899 906 842 524 50 0.000 000 000 000 000 888 178 419 700 125 232 338 905 334 472 656 25 

2 251 799 813 685 248 51 0.000 000 000 000 000 444 089 209 850 062 616 169 452 667 236 328 125 

4 503 599 62? 370 496 52 0.000 000 000 000 000 222 044 604 925 031 308 084 726 333 618 164 062 5 

9 007 199 254 740 992 53 0.000 000 000 000 000 111 022 302 462 515 654 042 363 166 809 082 031 25 

18 014 398 509 481 984 54 0.000 000 000 000 000 055 511 151 231 257 827 021 181 583 404 541 015 625 

36 028 797 018 963 968 55 0.000 000 000 000 000 027 755 575 615 628 913 510 590 791 702 270 507 812 5 

72 057 594 037 927 936 56 0.000 000 000 000 000 013 87? 787 807 814 456 755 295 395 851 135 253 906 25 

144 115 188 075 855 872 57 0.000 000 000 000 000 006 938 893 903 907 228 377 647 697 925 567 676 950 125 

288 230 376 151 711 744 58 0.000 000 000 000 000 003 469 446 951 953 614 188 823 848 962 783 813 476 562 5 

576 460 752 303 423 488 59 0.000 000 000 000 000 001 734 723 475 976 807 094 411 924 481 391 906 738 281 25 

1 152 921 504 606 846 976 60 0.000 000 000 000 000 000 867 361 737 988 403 547 205 962 240 695 953 369 140 625 

2 305 843 009 213 693 952 61 0.000 000 000 000 000 000 433 680 868 994 201 773 602 981 120 347 976 684 570 312 5 
4 611 686 018 42? 387 904 62 0.000 000 000 000 000 000 216 840 434 497 100 886 801 490 560 173 988 342 285 156 25 
9 223 372 036 854 775 808 63 0.000 000 000 000 000 000 108 420 217 248 550 443 400 745 280 086 994 171 142 578 125 
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Appendix D. Binary-Decimal-Hexadecimai Conversion Tables 













POWERS OF 16 (IN BASE 10) 


















16 n 


n 






16 


-n 
















1 





0.10000 


00000 


00000 


00000 


X 


10 












16 


1 


0.62500 


00000 


00000 


00000 


X 


10"' 












256 


2 


0.39062 


50000 


00000 


00000 


X 


10" 2 










4 


096 


3 


0.24414 


06250 


00000 


00000 


X 


10- 3 










65 


536 


4 


0.15258 


78906 


25000 


00000 


X 


10" 4 








1 


048 


576 


5 


0.95367 


43164 


06250 


00000 


X 


10~ 6 








16 


777 


216 


6 


0.59604 


64477 


53906 


25000 


X 


10" 7 








268 


435 


456 


7 


0.37252 


90298 


46191 


40625 


X 


10" 8 






4 


294 


967 


296 


8 


0.23283 


06436 


53869 


62891 


X 


w~ 9 






68 


719 


476 


736 


9 


0.14551 


91522 


83668 


51807 


X 


10" 10 




1 


099 


511 


627 


776 


10 


0.90949 


47017 


72928 


23792 


X 


10" 12 




17 


592 


186 


044 


416 


11 


0.56843 


41886 


08080 


14870 


X 


10" 13 




281 


474 


976 


710 


656 


12 


0.35527 


13678 


80050 


09294 


X 


10' 14 


4 


503 


599 


627 


370 


496 


13 


0.22204 


46049 


25031 


30808 


X 


10" 15 


72 


057 


594 


037 


927 


936 


14 


0.13877 


78780 


78144 


56755 


X 


10~ 16 


1 152 


921 


504 


606 


846 


976 


15 


0.86736 


17379 


88403 


54721 


X 


10" 18 



POWERS OF 10 (IN BASE 16) 









10 


n 




10 


■n 














1 





1 .0000 


0000 


0000 


0000 












A 


1 


0.1999 


9999 


9999 


999 A 












64 


2 


0.28F5 


C28F 


5C28 


F5C3 


X 


16' 1 








3E8 


3 


0.4189 


374B 


C6A7 


EF9E 


X 


16" 2 








2710 


4 


0.68DB 


8BAC 


710C 


B296 


X 


16~ 3 






1 


86A0 


5 


0.A7C5 


AC47 


1847 


8423 


X 


16~ 4 






F 


4240 


6 


0.1 0C6 


F7A0 


B5ED 


8D37 


X 


16~ 4 






98 


9680 


7 


0.1 AD7 


F29A 


BCAF 


4858 


X 


16" s 






5F5 


E100 


8 


0.2AF3 


1DC4 


6118 


73BF 


X 


16~ 6 






3B9A 


CA00 


9 


0.44B8 


2FA0 


9B5A 


52CC 


X 


16~ 7 




2 


540B 


E400 


10 


0.6DF3 


7F67 


SEF6 


EADF 


X 


16~ 8 




17 


4876 


E800 


11 


O.AFEB 


FF08 


CB24 


AAFF 


X 


16~ 9 




E8 


D4A5 


1000 


12 


0.1197 


9981 


2DEA 


1119 


X 


16" 9 




918 


4E72 


A0O0 


13 


0.1 C25 


C268 


4976 


81C2 


X 


16-'° 




5AF3 


107A 


4000 


14 


0.2D09 


370D 


4257 


3804 


X 


16" lJ 


3 


8D7E 


A4C6 


8000 


15 


0.480E 


BE7B 


9D58 


566D 


X 


16" 12 


23 


8652 


6FC1 


0000 


16 


0.734A 


CA5F 


6226 


FOAE 


X 


16" 13 


163 


4578 


5D8A 


0000 


17 


0.B877 


AA32 


36A4 


B449 


X 


16" !4 


DEO 


B683 


A764 


0000 


18 


0.1272 


5DD1 


D243 


ABA1 


X 


16~ i4 


8AC7 


2304 


89E8 


0000 


19 


0.1 D83 


C94F 


B6D2 


AC35 


X 


16~ i5 
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Appendix D. Binary-Decinal-Hexadecimal Conversion Tables 

HEXADECIMAL-DECIMAL INTEGER CONVERSION 

The table below provides for direct conversions between hexadecimal integers in the range 0-FFF and decimal integers in the 
range 0-4095. For conversion of larger integers, the table values may be added to the following figures: 



xadecimal 


Decimal 


Hexadecimal 


Decimal 


01 000 


4 096 


20 000 


131 072 


02 000 


8 192 


30 000 


196 608 


03 000 


12 288 


40 000 


262 144 


04 000 


16 384 


50 000 


327 680 


05 000 


20 480 


60 000 


393 216 


06 000 


24 576 


70 000 


458 752 


07 000 


28 672 


80 000 


524 288 


08 000 


32 768 


90 000 


589 824 


09 000 


36 864 


AO 000 


655 360 


OA00O 


40 960 


BO 000 


720 896 


0B 000 


45 056 


CO 000 


786 432 


OCOOO 


49 152 


DO 000 


851 968 


0D000 


53 248 


E0 000 


917 504 


0E000 


57 344 


F0 000 


983 040 


OF 000 


61 440 


100 000 


1 048 576 


10 000 


65 536 


200 000 


2 097 152 


11 000 


69 632 


300 000 


3 145 728 


12 000 


73 728 


400 000 


4 194 304 


13 000 


77 824 


500 000 


5 242 880 


14 000 


81 920 


600 000 


6 291 456 


15 000 


86 016 


700 000 


7 340 032 


16 000 


90 112 


800 000 


8 388 608 


17 000 


94 208 


900 000 


9 437 184 


18 000 


98 304 


A00 000 


10 485 760 


19 000 


102 400 


BOO 000 


1 1 534 336 


1A000 


106 496 


COO 000 


12 582 912 


IB 000 


110 592 


D00 000 


13 631 488 


1C000 


114 688 


E00 000 


14 680 064 


1D 000 


118 784 


F00 000 


15 728 640 


1E000 


122 880 


1 000 000 


16 777 216 


1F000 


126 976 


2 000 000 


33 554 432 








1 


2 


3 


4 


5 


6 


7 


8 


9 


A 


B 


C 


D 


E 


F 


000 


0000 


0001 


0d02 


0003 


0004 


0005 


0006 


0007 


0008 


0009 


0010 


0011 


0012 


0013 


0014 


0015 


010 


0016 


0017 


0018 


0019 


0020 


0021 


0022 


0023 


0024 


0025 


0026 


0027 


0028 


0029 


0030 


0031 


020 


0032 


0033 


0034 


0035 


0036 


0037 


0038 


0039 


0040 


0041 


0042 


0043 


0044 


0045 


0046 


0047 


030 


0048 


0049 


0050 


0051 


0052 


0053 


0054 


0055 


0056 


0057 


0058 


0059 


0060 


0061 


0062 


0063 


040 


0064 


0065 


0066 


0067 


0068 


0069 


0070 


0071 


0072 


0073 


0074 


0075 


0076 


0077 


0078 


0079 


050 


0080 


0081 


0082 


0083 


0084 


0085 


0086 


0087 


0088 


0089 


0090 


0091 


0092 


0093 


0094 


0095 


060 


0096 


0097 


0098 


0099 


0100 


0101 


0102 


0103 


0104 


0105 


0106 


0107 


0108 


0109 


0110 


0111 


070 


0112 


0113 


14 


0115 


0116 


0117 


0118 


0119 


0120 


0121 


0122 


0123 


0124 


0125 


0126 


0127 


080 


0128 


0129 


30 


0131 


0132 


0133 


0134 


0135 


0136 


0137 


0138 


0139 


0140 


0141 


0142 


0143 


090 


0144 


0145 


46 


0147 


0148 


0149 


0150 


0151 


0152 


0153 


0154 


0155 


0156 


0157 


0158 


0159 


0A0 


0160 


0161 


62 


0163 


0164 


0165 


0166 


0167 


0168 


0169 


0170 


0171 


0172 


0173 


0174 


0175 


OBO 


0176 


0177 


78 


0179 


0180 


0181 


0182 


0183 


0184 


0185 


0186 


0187 


0188 


0189 


0190 


0191 


0C0 


0192 


0193 


94 


0195 


0196 


0197 


0198 


0199 


0200 


0201 


0202 


0203 


0204 


0205 


0206 


0207 


0D0 


0208 


0209 


o:mo 


0211 


0212 


0213 


0214 


0215 


0216 


0217 


0218 


0219 


0220 


0221 


0222 


0223 


OEO 


0224 


0225 


0>26 


0227 


0228 


0229 


0230 


0231 


0232 


0233 


0234 


0235 


0236 


0237 


0238 


0239 


0F0 


0240 


0241 


0:M2 


0243 


0244 


0245 


0246 


0247 


0248 


0249 


0250 


0251 


0252 


0253 


0254 


0255 
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Appendix D. Binary-Decimal-Hexadecimal Conversion Tables 

HEXADECIMAL-DECIMAL INTEGER CONVERSION (Cont'd) 








1 


2 


3 


4 


5 


6 


7 


8 


9 


A 


B 


C 


D 


E 


F 


100 


0256 


0257 


0258 


0259 


0260 


0261 


0262 


0263 


0264 


0265 


0266 


0267 


0268 


0269 


0270 


0271 


110 


0272 


0273 


0274 


0275 


0276 


0277 


0278 


0279 


0280 


0281 


0282 


0283 


0284 


0285 


0286 


0287 


120 


0288 


0289 


0290 


0291 


0292 


0293 


0294 


0295 


0296 


0297 


0298 


0299 


0300 


0301 


0302 


0303 


130 


0304 


0305 


0306 


0307 


0308 


0309 


0310 


0311 


0312 


0313 


0314 


0315 


0316 


0317 


0318 


0319 


140 


0320 


0321 


0322 


0323 


0324 


0325 


0326 


0327 


0328 


0329 


0330 


0331 


0331 


0333 


0334 


0335 


150 


0336 


0337 


0338 


0339 


0340 


0341 


0342 


0343 


0344 


0345 


0346 


0347 


0348 


0349 


0350 


0351 


160 


0352 


0353 


0354 


0355 


0356 


0357 


0358 


0359 


0360 


0361 


0362 


0363 


0364 


0365 


0366 


0367 


170 


0368 


0369 


0370 


0371 


0372 


0373 


0374 


0375 


0376 


0377 


0378 


0379 


0380 


0381 


0382 


0383 


180 


0384 


0385 


0386 


0387 


0388 


0389 


0390 


0391 


0392 


0393 


0394 


0395 


0396 


0397 


0398 


0399 


190 


0400 


0401 


0402 


0403 


0404 


0405 


0406 


0407 


0408 


0409 


0410 


0411 


0412 


0413 


0414 


0415 


1A0 


0416 


0417 


0418 


0419 


0420 


0421 


0422 


0423 


0424 


0425 


0426 


0427 


0428 


0429 


0430 


0431 


1B0 


0432 


0433 


0434 


0435 


0436 


0437 


0438 


0439 


0440 


0441 


0442 


0443 


0444 


0445 


0446 


0447 


1C0 


0448 


0449 


0450 


0451 


0452 


0453 


0454 


0455 


0456 


0457 


0458 


0459 


0460 


0461 


0462 


0463 


1D0 


0464 


0465 


0466 


0467 


0468 


0469 


0470 


0471 


0472 


0473 


0474 


0475 


0476 


0477 


0478 


0479 


1E0 


0480 


0481 


0482 


0483 


0484 


0485 


0486 


0487 


0488 


0489 


0490 


0491 


0492 


0493 


0494 


0495 


1F0 


0496 


0497 


0498 


0499 


0500 


0501 


0502 


0503 


0504 


0505 


0506 


0507 


0508 


0509 


0510 


0511 


200 


0512 


0513 


0514 


0515 


0516 


0517 


0518 


0519 


0520 


0521 


0522 


0523 


0524 


0525 


0526 


0527 


210 


0528 


0529 


0530 


0531 


0532 


0533 


0534 


0535 


0536 


0537 


0538 


0539 


0540 


0541 


0542 


0543 


220 


0544 


0545 


0546 


0547 


0548 


0549 


0550 


0551 


0552 


0553 


0554 


0555 


0556 


0557 


0558 


0559 


230 


0560 


0561 


0562 


0563 


0564 


0565 


0566 


0567 


0568 


0569 


0570 


0571 


0572 


0573 


0574 


0575 


240 


0576 


0577 


0578 


0579 


0580 


0581 


0582 


0583 


0584 


0585 


0586 


0587 


0588 


0589 


0590 


0591 


250 


0592 


0593 


0594 


0595 


0596 


0597 


0598 


0599 


0600 


0601 


0602 


0603 


0604 


0605 


0606 


0607 


260 


0608 


0609 


0610 


0611 


0612 


0613 


0614 


0615 


0616 


0617 


0618 


0619 


0620 


0621 


0622 


0623 


270 


0624 


0625 


0626 


0627 


0628 


0629 


0630 


0631 


0632 


0633 


0634 


0635 


0636 


0637 


0638 


0639 


280 


0640 


0641 


0642 


0643 


0644 


0645 


0646 


0647 


0648 


0649 


0650 


0651 


0652 


0653 


0654 


0655 


290 


0656 


0657 


0658 


0659 


0660 


0661 


0662 


0663 


0664 


0665 


0666 


0667 


0668 


0669 


0670 


0671 


2A0 


0672 


0673 


0674 


0675 


0676 


0677 


0678 


0679 


0680 


0681 


0682 


0683 


0684 


0685 


0686 


0687 


2B0 


0688 


0689 


0690 


0691 


0692 


0693 


0694 


0695 


0696 


0697 


0698 


0699 


0700 


0701 


0702 


0703 


2C0 


0704 


0705 


0706 


0707 


0708 


0709 


0710 


0711 


0712 


0713 


0714 


0715 


0716 


0717 


0718 


0719 


2D0 


0720 


0721 


0722 


0723 


0724 


0725 


0726 


0727 


0728 


0729 


0730 


0731 


0732 


0733 


0734 


0735 


2E0 


0736 


0737 


0738 


0739 


0740 


0741 


0742 


0743 


0744 


0745 


0746 


0747 


0748 


0749 


0750 


0751 


2F0 


0752 


0753 


0754 


0755 


0756 


0757 


0758 


0759 


0760 


0761 


0762 


0763 


0764 


0765 


0766 


0767 


300 


0768 


0769 


0770 


0771 


0772 


0773 


0774 


0775 


0776 


0777 


0778 


0779 


0780 


0781 


0782 


0783 


310 


0784 


0785 


0786 


0787 


0788 


0789 


0790 


0791 


0792 


0793 


0794 


0795 


0796 


0797 


0798 


0799 


320 


0800 


0301 


0802 


0803 


0804 


0805 


0806 


0807 


0808 


0809 


0810 


0811 


0812 


0813 


0814 


0815 


330 


0816 


0817 


0818 


0819 


0820 


0821 


0822 


0823 


0824 


0825 


0826 


0827 


0828 


0829 


0830 


0831 


340 


0832 


0833 


0834 


0835 


0836 


0837 


0838 


0839 


0840 


0841 


0842 


0843 


0844 


0845 


0846 


0847 


350 


0848 


0849 


0850 


0851 


0852 


0853 


0854 


0855 


0856 


0857 


0858 


0859 


0860 


0861 


0862 


0863 


360 


0864 


0865 


0866 


0867 


0868 


0869 


0870 


0871 


0872 


0873 


0874 


0875 


0876 


0877 


0878 


0879 


370 


0880 


0881 


0882 


0883 


0884 


0885 


0886 


0887 


0888 


0889 


0890 


0891 


0892 


0893 


0894 


0895 


380 


0896 


0897 


0898 


0899 


0900 


0901 


0902 


0903 


0904 


0905 


0906 


0907 


0908 


0909 


0910 


0911 


390 


0212 


0913 


0914 


0915 


0916 


0917 


0918 


0919 


0920 


0921 


0922 


0923 


0924 


0925 


0926 


0927 


3A0 


0928 


0929 


0930 


0931 


0932 


0933 


0934 


0935 


0936 


0937 


0938 


0939 


0940 


0941 


0942 


0943 


3B0 


0944 


0945 


0946 


0947 


0948 


0949 


0950 


0951 


0952 


0953 


0954 


0955 


0956 


0957 


0958 


0959 


3C0 


0960 


0961 


0962 


0963 


0964 


0965 


0986 


0967 


0968 


0969 


0970 


0971 


0972 


0973 


0974 


0975 


3D0 


0976 


0977 


0978 


0979 


0980 


0981 


0982 


0983 


0984 


0985 


0986 


0987 


0988 


0989 


0990 


0991 


3E0 


0992 


0993 


0994 


0995 


0996 


0997 


0998 


0999 


1000 


1001 


1002 


1003 


1004 


1005 


1006 


1007 


3F0 


1008 


1009 


1010 


1011 


1012 


1013 


1014 


1015 


1016 


1017 


1018 


1019 


1020 


1021 


1022 


1023 
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Appendix D. Binary-De< imal-Hexadecimal Conversion Tables 

HEXADECIMAL-DECIMAL INTEGER CONVERSION (Cont'd) 








1 


2 


3 


4 


5 


6 


"7 


8 


9 


A 


B 


C 


D 


E 


F 


400 


1024 


1025 


1026 


1027 


1028 


1029 


1030 


1031 


1032 


1033 


1034 


1035 


1036 


1037 


1038 


1039 


410 


1040 


1041 


1042 


1043 


1044 


1045 


1046 


1047 


1048 


1049 


1050 


1051 


1052 


1053 


1054 


1055 


420 


1056 


1057 


1058 


1059 


1060 


1061 


1062 


1063 


1064 


1065 


1066 


1067 


1068 


1069 


1070 


1071 


430 


1072 


1073 


1074 


1075 


1076 


107? 


1078 


1079 


1080 


1081 


1082 


1083 


1084 


1085 


1086 


1087 


440 


1088 


1089 


1090 


1091 


1092 


1093 


1094 


1095 


1096 


1097 


1098 


1099 


1100 


1101 


1102 


1103 


450 


1104 


1105 


1106 


1107 


1108 


1109 


1110 


1111 


1112 


1113 


1114 


1115 


1116 


1117 


1118 


1119 


460 


1120 


1121 


1122 


1123 


1124 


1125 


1126 


1127 


1128 


1129 


1130 


1131 


1132 


1133 


1134 


1135 


470 


1136 


1137 


1138 


1139 


1140 


1141 


1142 


1143 


1144 


1145 


1146 


1147 


1148 


1149 


1150 


1151 


480 


1152 


1153 


1154 


1155 


1156 


1157 


1158 


1159 


1160 


1161 


1162 


1163 


1164 


1165 


1166 


1167 


490 


1168 


1169 


1170 


1171 


1172 


1173 


1174 


1175 


1176 


117? 


1178 


1179 


1180 


1181 


1182 


1183 


4A0 


1184 


1185 


1186 


1187 


1188 


1189 


1190 


1191 


1192 


1193 


1194 


1195 


1196 


1197 


1198 


1199 


4B0 


1200 


1201 


1202 


1203 


1204 


1205 


1206 


1207 


1208 


1209 


1210 


1211 


1212 


1213 


1214 


1215 


4C0 


1216 


1217 


1218 


1219 


1220 


1221 


1222 


1223 


1224 


1225 


1226 


1227 


1228 


1229 


1230 


1231 


4D0 


1232 


1233 


1234 


1235 


1236 


1237 


1238 


1239 


1240 


1241 


1242 


1243 


1244 


1245 


1246 


1247 


4E0 


1248 


1249 


1250 


1251 


1252 


1253 


1254 


1255 


1256 


1257 


1258 


1259 


1260 


1261 


1262 


1263 


4F0 


1264 


1265 


1266 


1267 


1268 


1269 


1270 


1271 


1272 


1273 


1274 


1275 


1276 


1277 


1278 


1279 


500 


1280 


1281 


1282 


1283 


1284 


1285 


1286 


1287 


1288 


1289 


1290 


1291 


1292 


1293 


1294 


1295 


510 


1296 


1297 


1298 


1299 


1300 


1301 


1302 


1303 


1304 


1305 


1306 


1307 


1308 


1309 


1310 


1311 


520 


1312 


1313 


1314 


1315 


1316 


1317 


1318 


1319 


1320 


1321 


1322 


1323 


1324 


1325 


1326 


1327 


530 


1328 


1329 


1330 


1331 


1332 


1333 


1334 


1335 


1336 


1337 


1338 


1339 


1340 


1341 


1342 


1343 


540 


1344 


1345 


1346 


1347 


1348 


1349 


1350 


1351 


1352 


1353 


1354 


1355 


1356 


1357 


1358 


1359 


550 


1360 


1361 


1362 


1363 


1364 


1365 


1366 


1367 


1368 


1369 


1370 


1371 


1372 


1373 


1374 


1375 


560 


1376 


1377 


1378 


1379 


1380 


1381 


1382 


1383 


1384 


1385 


1386 


1387 


1388 


1389 


1390 


1391 


570 


1392 


1393 


1394 


1395 


1396 


1397 


1398 


1399 


1400 


1401 


1402 


1403 


1404 


1405 


1406 


1407 


580 


1408 


1409 


1410 


1411 


1412 


1413 


1414 


1415 


1416 


1417 


1418 


1419 


1420 


1421 


1422 


1423 


590 


1424 


1425 


1426 


1427 


1428 


1429 


1430 


1431 


1432 


1433 


1434 


1435 


1436 


1437 


1438 


1439 


SAO 


1440 


1441 


1442 


1443 


1444 


1445 


1446 


1447 


1448 


1449 


1450 


1451 


1452 


1453 


1454 


1455 


5B0 


1456 


1457 


1458 


1459 


1460 


1461 


1462 


1463 


1464 


1465 


1466 


1467 


1468 


1469 


1470 


1471 


5C0 


1472 


1473 


1474 


1475 


1476 


1477 


1478 


1479 


1480 


1481 


1482 


1483 


1484 


1485 


1486 


1487 


5D0 


1488 


1489 


1490 


1491 


1492 


1493 


1494 


1495 


1496 


1497 


1498 


1499 


1500 


1501 


1502 


1503 


5E0 


1504 


1505 


1506 


1507 


1508 


1509 


1510 


1511 


1512 


1513 


1514 


1515 


1516 


151? 


1518 


1519 


5F0 


1520 


1521 


1522 


1523 


1524 


1525 


1526 


1527 


1528 


1529 


1530 


1531 


1532 


1533 


1534 


1535 


600 


1536 


1537 


1538 


1539 


1540 


1541 


1542 


1543 


1544 


1545 


1546 


1547 


1548 


1549 


1550 


1551 


610 


1552 


1553 


1554 


1555 


1556 


1557 


1558 


1559 


1560 


1561 


1562 


1563 


1564 


1565 


1566 


1567 


620 


1568 


1569 


1570 


1571 


1572 


1573 


1574 


1575 


1576 


1577 


1578 


1579 


1580 


1581 


1582 


1583 


630 


1584 


1585 


1586 


1587 


1588 


1589 


1590 


1591 


1592 


1593 


1594 


1595 


1596 


1597 


1598 


1599 


640 


1600 


1601 


1602 


1603 


1604 


1605 


1606 


1607 


1608 


1609 


1610 


1611 


1612 


1613 


1614 


1615 


650 


1616 


1617 


1618 


1619 


1620 


1621 


1622 


1623 


1624 


1625 


1626 


1627 


1628 


1629 


1630 


1631 


660 


1632 


1633 


1634 


1635 


1636 


1637 


1638 


1639 


1640 


1641 


1642 


1643 


1644 


1645 


1646 


1647 


670 


1648 


1649 


1650 


1651 


1652 


1653 


1654 


1655 


1656 


1657 


1658 


1659 


1660 


1661 


1662 


1663 


680 


1664 


1665 


1666 


1667 


1668 


1669 


1670 


1671 


1672 


1673 


1674 


1675 


1676 


1677 


1678 


1679 


eso 


1680 


1681 


1682 


1683 


1684 


1685 


1686 


1687 


1688 


1689 


1690 


1691 


1692 


1693 


1694 


1695 


6A0 


1698 


1697 


1698 


1699 


1700 


1701 


1702 


1703 


1704 


1705 


1706 


1707 


1708 


1709 


1710 


1711 


6B0 


1712 


1713 


1714 


1715 


1716 


1717 


1718 


1719 


1720 


1721 


1722 


1723 


1724 


1725 


1726 


1727 


6C0 


1728 


1729 


1730 


1731 


1732 


1733 


1734 


1735 


1736 


1737 


1738 


1739 


1740 


1741 


1742 


1743 


6D0 


1744 


1745 


1746 


1747 


1748 


1749 


1750 


1751 


1752 


1753 


1754 


1755 


1756 


1757 


1758 


1759 


6E0 


1760 


1761 


1762 


1763 


1764 


1765 


1766 


1767 


1768 


1769 


1770 


1771 


1772 


1773 


1774 


1775 


6F0 


1776 


1777 


1778 


1779 


1780 


1781 


1782 


1783 


1784 


1785 


1786 


1787 


1788 


1789 


1790 


1791 
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Appendix D. Binary-Decimal-Hexadecimal Conversion Tables 

HEXADECIMAL-DECIMAL INTEGER CONVERSION (Cont'd) 








1 


2 


3 


4 


5 


6 


7 


8 


9 


A 


B 


C 


D 


E 


F 


700 


1792 


1793 


1794 


1795 


1796 


1797 


1798 


1799 


1800 


1801 


1802 


1803 


1804 


1805 


1806 


1807 


710 


1808 


1809 


1810 


1811 


1812 


1813 


1814 


1815 


1816 


1817 


1818 


1819 


1820 


1821 


1822 


1823 


720 


1824 


1825 


1826 


1827 


1828 


1829 


1830 


1831 


1832 


1833 


1834 


1835 


1836 


1837 


1838 


1839 


730 


1840 


1841 


1842 


1843 


1844 


1845 


1846 


1847 


1848 


1849 


1850 


1851 


1852 


1853 


1854 


1855 


740 


1856 


1857 


1858 


1859 


1860 


1861 


1862 


1863 


1864 


1865 


1866 


1867 


1868 


1869 


1870 


1871 


750 


1872 


1873 


1874 


1875 


1876 


1877 


1878 


1879 


1880 


1881 


1882 


1883 


1884 


1885 


1886 


1887 


760 


1888 


1889 


1890 


1891 


1892 


1893 


1894 


1895 


1896 


1897 


1898 


1899 


1900 


1901 


1902 


1903 


770 


1904 


1905 


1906 


1907 


1908 


1909 


1910 


1911 


1912 


1913 


1914 


1915 


1913 


1917 


1918 


1919 


780 


1920 


1921 


1922 


1923 


1924 


1925 


1926 


1927 


1928 


1929 


1930 


1931 


1932 


1933 


1934 


1935 


790 


1936 


1937 


1938 


1939 


1940 


1941 


1942 


1943 


1944 


1945 


1946 


1947 


1948 


1949 


1950 


1951 


7A0 


1952 


1953 


1954 


1955 


1956 


1957 


1958 


1959 


1960 


1961 


1962 


1963 


1964 


1965 


1966 


1967 


780 


1968 


1969 


1970 


1971 


1972 


1973 


1974 


1975 


1976 


1977 


1978 


1979 


1980 


1981 


1982 


1983 


7C0 


1984 


1985 


1986 


1987 


1988 


1989 


1990 


1991 


1992 


1993 


1994 


1995 


1996 


1997 


1998 


1999 


7D0 


2000 


2001 


2002 


2003 


2004 


2005 


2006 


2007 


2008 


2009 


2010 


2011 


2012 


2013 


2014 


2015 


7E0 


2016 


2017 


2018 


2019 


2020 


2021 


2022 


2023 


2024 


2025 


2026 


2027 


2028 


2029 


2030 


2031 


7F0 


2032 


2033 


2034 


2035 


2036 


2037 


2038 


2039 


2040 


2041 


2042 


2043 


2044 


2045 


2046 


2047 


800 


2048 


2049 


2050 


2051 


2052 


2053 


2054 


2055 


2056 


2057 


2058 


2059 


2060 


2061 


2062 


2063 


810 


2064 


2065 


2066 


2067 


2068 


2069 


2070 


2071 


2072 


2073 


2074 


2075 


2076 


2077 


2078 


2079 


820 


2080 


2081 


2082 


2083 


2084 


2085 


2086 


2087 


2088 


2089 


2090 


2091 


2092 


2093 


2094 


2095 


830 


2096 


2097 


2098 


2099 


2100 


2101 


2102 


2103 


2104 


2105 


2106 


2107 


2108 


2109 


2110 


2111 


840 


2112 


2113 


2114 


2115 


2116 


2117 


2118 


2119 


2120 


2121 


2122 


2123 


2124 


2125 


2126 


2127 


850 


2128 


2129 


2130 


2131 


2132 


2133 


2134 


2135 


2136 


2137 


2138 


2139 


2140 


2141 


2142 


2143 


860 


2144 


2145 


2146 


2147 


2148 


2149 


2150 


2151 


2152 


2153 


2154 


2155 


2156 


2157 


2158 


2159 


870 


2160 


2161 


2162 


2163 


2164 


2165 


2166 


2167 


2168 


2169 


2170 


2171 


2172 


2173 


2174 


2175 


880 


2176 


2177 


2178 


2179 


2180 


2181 


2182 


2183 


2184 


2185 


2186 


2187 


2188 


2189 


2190 


2191 


890 


2192 


2193 


2194 


2195 


2196 


2197 


2198 


2199 


2200 


2201 


2202 


2203 


2204 


2205 


2206 


2207 


SAO 


2208 


2209 


2210 


2211 


2212 


2213 


2214 


2215 


2216 


2217 


2218 


2219 


2220 


2221 


2222 


2223 


8B0 


2224 


2225 


2226 


2227 


2228 


2229 


2230 


2231 


2232 


2233 


2234 


2235 


2236 


2237 


2238 


2239 


8C0 


2240 


2241 


2242 


2243 


2244 


2245 


2246 


2247 


2248 


2249 


2250 


2251 


2252 


2253 


2254 


2255 


8D0 


2256 


2257 


2258 


2259 


2260 


2261 


2262 


2263 


2264 


2265 


2266 


2267 


2268 


2269 


2270 


2271 


8E0 


2272 


2273 


2274 


2275 


2276 


2277 


2278 


2279 


2280 


2281 


2282 


2283 


2284 


2285 


2286 


2287 


8F0 


2288 


2289 


2290 


2291 


2292 


2293 


2294 


2295 


2296 


2297 


2298 


2299 


2300 


2301 


2302 


2303 


900 


2304 


2305 


2306 


2307 


2308 


2309 


2310 


2311 


2312 


2313 


2314 


2315 


2316 


2317 


2318 


2319 


910 


2320 


2321 


2322 


2323 


2324 


2325 


2326 


2327 


2328 


2329 


2330 


2331 


2332 


2333 


2334 


2335 


920 


2336 


2337 


2338 


2339 


2340 


2341 


2342 


2343 


2344 


2345 


2346 


2347 


2348 


2349 


2350 


2351 


930 


2352 


2353 


2354 


2355 


2356 


2357 


2358 


2359 


2360 


2361 


2362 


2363 


2364 


2365 


2366 


2367 


940 


2368 


2369 


2370 


2371 


2372 


2373 


2374 


2375 


2376 


2377 


2378 


2379 


2380 


2381 


2382 


2383 


950 


2384 


2385 


2386 


2387 


2388 


2389 


2390 


2391 


2392 


2393 


2394 


2395 


2396 


2397 


2398 


2399 


960 


2400 


2401 


2402 


2403 


2404 


2405 


2406 


2407 


2408 


2409 


2410 


2411 


2412 


2413 


2414 


2415 


970 


2416 


2417 


2418 


2419 


2420 


2421 


2422 


2423 


2424 


2425 


2426 


2427 


2428 


2429 


2430 


2431 


980 


2432 


2433 


2434 


2435 


2436 


2437 


2438 


2439 


2440 


2441 


2442 


2443 


2444 


2445 


2446 


2447 


990 


2448 


2449 


2450 


2451 


2452 


2453 


2454 


2455 


2456 


2457 


2458 


2459 


2460 


2461 


2462 


2463 


9A0 


2464 


2465 


2466 


2467 


2468 


2469 


2470 


2471 


2472 


2473 


2474 


2475 


2476 


2477 


2478 


2479 


980 


2480 


2481 


2482 


2483 


2484 


2485 


2486 


2487 


2488 


2489 


2490 


2491 


2492 


2493 


2494 


2495 


9C0 


2496 


2497 


2498 


2499 


2500 


2501 


2502 


2503 


2504 


2505 


2508 


2507 


2508 


2509 


2510 


2511 


9D0 


2512 


2513 


2514 


2515 


2516 


2517 


2518 


2519 


2520 


2521 


2522 


2523 


2524 


2525 


2526 


2527 


9E0 


2528 


2529 


2530 


2531 


2532 


2533 


2534 


2535 


2536 


2537 


2538 


2539 


2540 


2541 


2542 


2543 


9F0 


2544 


2545 


2546 


2547 


2548 


2549 


2550 


2551 


2552 


2553 


2554 


2555 


2556 


2557 


2558 


2559 
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HEXADECIMAL-DECIMAL INTEGER CONVERSION (Cont'd) 













1 


2 


3 


4 


5 


6 


7 


8 


9 


A 


B 


C 


D 


E 


F 


A00 


2560 


2561 


2562 


2563 


2564 


2565 


2566 


2567 


2568 


2569 


2570 


2571 


2572 


2573 


2574 


2575 


A10 


2576 


2577 


2578 


2579 


2580 


2581 


2582 


2583 


2584 


2585 


2586 


2587 


2588 


2589 


2590 


2591 


A20 


2592 


2593 


2594 


2595 


2596 


2597 


2598 


2599 


2600 


2601 


2602 


2603 


2604 


2605 


2606 


2607 


A30 


2608 


2609 


2610 


2611 


2612 


2613 


2614 


2615 


2616 


2617 


2618 


2619 


2620 


2621 


2622 


2623 


A40 


2624 


2625 


2626 


2627 


2628 


2629 


2630 


2631 


2632 


2633 


2634 


2635 


2636 


2637 


2638 


2639 


A50 


2640 


2641 


2642 


2643 


2644 


2645 


2646 


2647 


2648 


2649 


2650 


2651 


2652 


2653 


2654 


2655 


A60 


2656 


2657 


2658 


2659 


2660 


2661 


2662 


2663 


2664 


2665 


2666 


2667 


2668 


2669 


2670 


2671 


A70 


2672 


2673 


2674 


2675 


2676 


2677 


2678 


2679 


2680 


2681 


2682 


2683 


2684 


2685 


2686 


2687 


A80 


2688 


2689 


2690 


2691 


2692 


2693 


2694 


2695 


2696 


2697 


2698 


2699 


2700 


2701 


2702 


2703 


A90 


2704 


2705 


2706 


2707 


2708 


2709 


2710 


2711 


2712 


2713 


2714 


2715 


2716 


2717 


2718 


2719 


AAO 


2720 


2721 


2722 


2723 


2724 


2725 


2726 


2727 


2728 


2729 


2730 


2731 


2732 


2733 


2734 


2735 


ABO 


2736 


2737 


2738 


2739 


2740 


2741 


2742 


2743 


2744 


2745 


2746 


2747 


2748 


2749 


2750 


2751 


ACO 


2752 


2753 


2754 


2755 


2756 


2757 


2758 


2759 


2760 


4761 


2762 


2763 


2764 


2765 


2766 


2767 


ADO 


2768 


2769 


2770 


2771 


2772 


2773 


2774 


2775 


2776 


2777 


2778 


2779 


2780 


2781 


2782 


2783 


AEO 


2784 


2785 


2786 


2787 


2788 


2789 


2790 


2791 


2792 


2793 


2794 


2795 


2796 


2797 


2798 


2799 


AFO 


2800 


2801 


2802 


2803 


2804 


2805 


2806 


2807 


2808 


2809 


2810 


2811 


2812 


2813 


2814 


2815 


800 


2816 


2817 


2818 


2819 


2820 


2821 


2822 


2823 


2824 


2825 


2826 


2827 


2828 


2829 


2830 


2831 


810 


2832 


2833 


2834 


2835 


2836 


2837 


2838 


2839 


2840 


2841 


2842 


2843 


2844 


2845 


2846 


2847 


820 


2848 


2849 


2850 


3851 


2852 


2853 


2854 


2855 


2856 


2857 


2858 


2859 


2860 


2861 


2862 


2863 


830 


2864 


2865 


2866 


2867 


2868 


2869 


2870 


2871 


2872 


2873 


2874 


2875 


2876 


2877 


2878 


2879 


840 


2880 


2881 


2882 


2883 


2884 


2885 


2866 


2887 


2888 


2889 


2890 


2891 


2892 


2893 


2894 


2895 


850 


2896 


2897 


2898 


2899 


2900 


2901 


2902 


2903 


2904 


2905 


2906 


2907 


2908 


2909 


2910 


2911 


B60 


2912 


2913 


2914 


2915 


2916 


2917 


2918 


2919 


2920 


2921 


2922 


2923 


2924 


2925 


2926 


2927 


870 


2928 


2929 


2930 


2931 


2932 


2933 


2934 


2935 


2936 


2937 


2938 


2939 


2940 


2941 


2942 


2943 


B80 


2944 


2945 


2946 


2947 


2948 


2949 


2950 


2951 


2952 


2953 


2954 


2955 


2956 


2957 


2958 


2959 


B90 


2960 


2961 


2962 


2963 


2964 


2965 


2966 


2967 


2968 


2969 


2970 


2971 


2972 


2973 


2974 


2975 


BAO 


2976 


2977 


2978 


2979 


2980 


2981 


2982 


2983 


2984 


2985 


2986 


2987 


2988 


2989 


2990 


2991 


BBO 


2992 


2993 


2994 


2995 


2996 


2997 


2998 


2999 


3000 


3001 


3002 


3003 


3004 


3005 


3006 


3007 


BCO 


3008 


3009 


3010 


3011 


3012 


3013 


3014 


3015 


3016 


3017 


3018 


3019 


3020 


3021 


3022 


3023 


BDO 


3024 


3025 


3026 


3027 


3028 


3029 


3030 


3031 


3032 


3033 


3034 


3035 


3036 


3037 


3038 


3039 


8E0 


3040 


3041 


3042 


3043 


3044 


3045 


3046 


3047 


3048 


3049 


3050 


3051 


3052 


3053 


3054 


3055 


8F0 


3056 


3057 


3058 


3059 


3060 


3061 


3062 


3063 


3064 


3065 


3066 


3067 


3068 


3069 


3070 


3071 


COO 


3072 


3073 


3074 


3075 


3076 


3077 


3078 


3079 


3080 


3081 


3082 


3083 


3084 


3085 


3086 


3087 


C10 


3088 


3089 


3090 


3091 


3092 


3093 


3094 


3095 


3096 


3097 


3098 


3099 


3100 


3101 


3102 


3103 


C20 


3104 


3105 


3106 


3107 


3108 


3109 


3110 


3111 


3112 


3113 


3114 


3115 


3116 


3117 


3118 


3119 


C30 


3120 


3121 


3122 


3123 


3124 


3125 


3126 


3127 


3128 


3129 


3130 


3131 


3132 


3133 


3134 


3135 


C40 


3136 


3137 


3138 


3139 


3140 


3141 


3142 


3143 


3144 


3145 


3146 


3147 


3148 


3149 


3150 


3151 


C50 


3152 


3153 


3154 


3155 


3156 


3157 


3158 


3159 


3160 


3161 


3162 


3163 


3164 


3165 


3166 


3167 


C60 


3168 


3169 


3170 


3171 


3172 


3173 


3174 


3175 


3176 


3177 


3178 


3179 


3180 


3181 


3182 


3183 


C70 


3184 


3185 


3186 


3187 


3188 


3189 


3190 


3191 


3192 


3193 


3194 


3195 


3196 


3197 


3198 


3199 


C80 


3200 


3201 


3202 


3203 


3204 


3205 


3206 


3207 


3208 


3209 


3210 


3211 


3212 


3213 


3214 


3215 


C90 


3216 


3217 


3218 


3219 


3220 


3221 


3222 


3223 


3224 


3225 


3226 


3227 


3228 


3229 


3230 


3231 


CAO 


3232 


3233 


3234 


3235 


3236 


3237 


3238 


3239 


3240 


3241 


3242 


3243 


3244 


3245 


3246 


3247 


C80 


3248 


3249 


3250 


3251 


3252 


3253 


3254 


3255 


3256 


3257 


3258 


3259 


3260 


3261 


3262 


3263 


CCO 


3264 


3265 


3266 


3267 


3268 


3269 


3270 


3271 


3272 


3273 


3274 


3275 


3276 


3277 


3278 


3279 


CDO 


3280 


3281 


3282 


3283 


3284 


3285 


3286 


3287 


3288 


3289 


3290 


3291 


3292 


3293 


3294 


3295 


CEO 


3296 


3297 


3298 


3299 


3300 


3301 


3302 


3303 


3304 


3305 


3306 


3307 


3308 


3309 


3310 


3311 


CFO 


3312 


3313 


3314 


3315 


3316 


3317 


3318 


3319 


3320 


3321 


3322 


3323 


3324 


3325 


3326 


3327 
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Appendix D. Binary-Decimai-Hexadecimal Conversion Tables 



HEXADECIMAL-DECIMAL INTEGER CONVERSION (Cont'd) 








1 2 


3 


4 5 


6 


7 


8 


9 


A 


B 


C 


D 


E 


F 


DOO 


3328 


3329 3330 


3331 


3332 3333 


3334 


3335 


3336 


3337 


3338 


3339 


3340 


3341 


3342 


3343 


D10 


3344 


3345 3346 


3347 


3348 3349 


3350 


3351 


3352 


3353 


3354 


3355 


3356 


3357 


3358 


3359 


D20 


3360 


3361 3362 


3363 


3364 3365 


3366 


3367 


3368 


3369 


3370 


3371 


3372 


3373 


3374 


3375 


D30 


3376 


3377 3378 


3379 


3380 3381 


3382 


3383 


3384 


3385 


3386 


3387 


3388 


3389 


3390 


3391 


D40 


3392 


3393 3394 


3395 


3396 3397 


3398 


3399 


3400 


3401 


3402 


3403 


3404 


3405 


3406 


3407 


D50 


3408 


3409 3410 


3411 


3412 3413 


3414 


3415 


3416 


3417 


3418 


3419 


3420 


3421 


3422 


3423 


D60 


3424 


3425 3426 


3427 


3428 3429 


3430 


3431 


3432 


3433 


3434 


3435 


3436 


3437 


3438 


3439 


D70 


3440 


3441 3442 


3443 


3444 3445 


3446 


3447 


3448 


3449 


3450 


3451 


3452 


3453 


3454 


3455 


D80 


3456 


3457 3458 


3459 


3460 3461 


3462 


3463 


3464 


3465 


3466 


3467 


3468 


3469 


3470 


3471 


D90 


3472 


3473 3474 


3475 


3476 3477 


3478 


3479 


3480 


3481 


3482 


3483 


3484 


3485 


3486 


3487 


DAO 


3488 


3489 3490 


3491 


3492 3493 


3494 


3495 


3496 


3497 


3498 


3499 


3500 


3501 


3502 


3503 


D80 


3504 


3505 3506 


3507 


3508 3509 


3510 


3511 


3512 


3513 


3514 


3515 


3516 


3517 


3518 


3519 


DCO 


3520 


3521 3522 


3523 


3524 3525 


3526 


3527 


3528 


3529 


3530 


3531 


3532 


3533 


3534 


3535 


DDO 


3536 


3537 3538 


3539 


3540 3541 


3542 


3543 


3544 


3545 


3546 


3547 


3548 


3549 


3550 


3551 


DEO 


3552 


3553 3554 


3555 


3556 3557 


3558 


3559 


3560 


3561 


3562 


3563 


3564 


3565 


3566 


3567 


DFO 


3568 


3569 3570 


3571 


3572 3573 


3574 


3575 


3576 


3577 


3578 


3579 


3580 


3581 


3582 


3583 


EDO 


3584 


3585 3586 


3587 


3588 3589 


3590 


3591 


3592 


3593 


3594 


3595 


3596 


3597 


3598 


3599 


EIO 


3600 


3601 3602 


3603 


3604 3605 


3606 


3607 


3608 


3609 


3610 


3611 


3612 


3613 


3614 


3615 


E20 


3616 


3617 3618 


3619 


3620 3621 


3622 


3623 


3624 


3625 


3626 


3627 


3628 


3629 


3630 


3631 


E30 


3632 


3633 3634 


3635 


3636 3637 


3638 


3639 


3640 


3641 


3642 


3643 


3644 


3645 


3646 


3647 


E40 


3648 


3649 3650 


3651 


3652 3653 


3654 


3655 


3656 


3657 


3658 


3659 


3660 


3661 


3662 


3663 


E50 


3664 


3665 3666 


3667 


3668 3669 


3670 


3671 


3672 


3673 


3874 


3675 


3676 


3677 


3678 


3679 


E60 


3680 


3681 3682 


3683 


3684 3685 


3686 


3687 


3688 


3689 


3690 


3691 


3692 


3693 


3694 


3695 


E70 


3696 


3697 3698 


3699 


3700 3701 


3702 


3703 


3704 


3705 


3706 


3707 


3708 


3709 


3710 


3711 


E80 3712 


3713 3714 


3715 


3716 3717 


3718 


3719 


3720 


3721 


3722 


3723 


3724 


3725 


3726 


3727 


E90 3728 


3729 3730 


3731 


3732 3733 


3734 


3735 


3736 


3737 


3738 


3739 


3740 


3741 


3742 


3743 


EAO 


3744 


3745 3746 


3747 


3748 3749 


3750 


3751 


3752 


3753 


3754 


3755 


3756 


3757 


3758 


3759 


EBO 


3760 


3761 3762 


3763 


3764 3765 


3766 


3767 


3768 


3769 


3770 


3771 


3772 


3773 


3774 


3775 


ECO 


3776 


3777 3778 


3779 


3780 3781 


3782 


3783 


3784 


3785 


3786 


3787 


3788 


3789 


3790 


3791 


EDO 


3792 


3793 3794 


3795 


3796 3797 


3798 


3799 


3800 


3801 


3802 


3803 


3804 


3805 


3806 


3807 


EEO 


3808 


3809 3810 


3811 


3812 3813 


3814 


3815 


3816 


3817 


3818 


3819 


3820 


3821 


3822 


3823 


EFO 


3824 


3825 3826 


3827 


3828 3829 


3830 


3831 


3832 


3833 


3834 


3835 


3836 


3837 


3838 


3839 


FOO 


3840 


3841 3842 


3843 


3844 3845 


3846 


3847 


3848 


3849 


3850 


3851 


3852 


3853 


3854 


3855 


F10 


3856 


3857 3858 


3859 


3860 3861 


3862 


3863 


3864 


3865 


3866 


3867 


3868 


3869 


3870 


3871 


F20 


3872 


3873 3874 


3875 


3876 3877 


3878 


3879 


3880 


3881 


3882 


3883 


3884 


3885 


3886 


3887 


F30 


3888 


3889 3890 


3891 


3892 3893 


3894 


3895 


3896 


3897 


3898 


3899 


3900 


3901 


3902 


3903 


F40 


3904 


3905 3906 


3907 


3908 3909 


3910 


3911 


3912 


3913 


3914 


3915 


3916 


3917 


3918 


3919 


F50 


3920 


3921 3922 


3923 


3924 3925 


3926 


3927 


3928 


3929 


3930 


3931 


3932 


3933 


3934 


3935 


F60 


3936 


3937 3938 


3939 


3940 3941 


3942 


3943 


3944 


3945 


3946 


3947 


3948 


3949 


3950 


3951 


F70 


3952 


3953 3954 


3955 


3956 3957 


3958 


3959 


3960 


3961 


3962 


3963 


3964 


3965 


3966 


3967 


F80 


3968 


3969 3970 


3971 


3972 3973 


3974 


3975 


3976 


3977 


3978 


3979 


3980 


3981 


3982 


3983 


F90 


3984 


3985 3986 


3987 


3988 3989 


3990 


3991 


3992 


3993 


3994 


3995 


3996 


3997 


3998 


3999 


FAO 


4000 


4001 4002 


4003 


4004 4005 


4006 


4007 


4008 


4009 


4010 


4011 


4012 


4013 


4014 


4015 


F80 


4016 


4017 4018 


4019 


4020 4021 


4022 


4023 


4024 


4025 


4026 


4027 


4028 


4029 


4030 


4031 


FCO 


4032 


4033 4034 


4035 


4036 4037 


4038 


4Q39 


4040 


4041 


4042 


4043 


4044 


4045 


4046 


4047 


FDO 


4048 


4049 4050 


4051 


4052 4053 


4054 


4055 


4056 


4057 


4058 


4059 


4060 


4061 


4062 


4063 


FEO 


4064 


4065 4066 


4067 


4068 4069 


4070 


4071 


4072 


4073 


4074 


4075 


4076 


4077 


4078 


4079 


FFO 


4080 


4081 4082 


4083 


4084 4085 


4086 


4087 


4088 


4089 


4090 


4091 


4092 


4093 


4094 


4095 
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LINK Progn.m ,..,.,......,..,.,..,..., = ,..., 4-12,4-14.4-15 

Linkage .,,,,.,,,.,,.,.,,,,,,,,,,...,,,,,, = .>, 4-1 6 

List Fiie .,..,...,.,,,.,.. ..,.,.,.. 1-1 

LOCAL Directive .,...,,,...,...,,.,..,,,- = ....,... 5-5 

LOCAL Symbols .._.,,,,,......,.,,..,.., 5-6 

LOCATE Program ,.,,..,.,,...,,,,,.. ,4-12,4-13,4-14,4-19 

Location Counter (Coding Rules) ,.,.,,,,,,,., ,.,....,. 2-6 

Location Counter Control (Absolute Mode) , . . . , . , . , , , . , . , ,,,,.,, 4-11 

Location Counter Control (Relocatable Mode) ,.,,,.,.,,,,,. , 4-14 

Logical Instructions . . , . . . , . . , . . , , . . , . , . . . . 1-17 

Logical Insti uctions, Summary ,.,,,,,.,,...■.,.,,,.,,,,,,., 3-6 

Logical Operators ,,,,,,,,,.,.,.,,,.,,,,,..,,.,,.,., 2-13 

LOW Operator ,....,.._., .,..,,.,,., 2-14, 3-2, 3-5,3-7,4-4 

LT Operatoi ,,,,.,.,,,,,,.,,,,,.,.,,.,,,,,,,,,,,, 2-13 

LXI (Load Register Pair Immediate) ,,..,..,,,,........,,...,, 3-35 

Macros .....,.,.,.,,,....,,..*,.>,, • . 5-1 

Macro Calls .,.,, = .:......,,,.,,...,.,,... 5-12 

Macro Defir ition ,,., = ,,.,,....= ..:,.,......., 5-4 

MACRO Diiective ..,,,,. = .,,,..,,.,.,...,...,..,... 5-4 

Macro Expansion , 5-1 5 

Macro Parameters ,,,,,....,.,.,.,..,..,,,....,.,>,. 5-5 

Macros versus Subroutines ,...,..,....,,.,,, = ,.,,,. = .,.. 5-3 

Manual Programming ,,,,.,,.,.,,,,.,.,,..,,......,..,, 1-3 

Memory ,,,.,,..,,,,.,,,..,,,,,..,,.,.., = ,,,,. 1-5 

Memory Management with Relocation ,,,.,,,....,,.,.,,...,,, 4-12 

Memory Reservation .,, = ..,.,.,,,.,...,,.,........>. 4-5 

MEMORY Reserved Word ,.,..., = ..,,...,.,.. , . . . . 4-19 

MOD Operator .,,,.....,,..,..,,,.... 2-12 

Modular Programming ..,.,.,..,.,.....,.,,. = 4-12 

MODULE Default Name ....,.,.,...,....,.,,,,,,.,.,,. 4-17 

MOV (Move) Instruction ,.,,,..,......,,,..,...,....... 3-36 

Multibyte Addition Routines : ,. : ....,, , , , . , , 6-1 1 

Muitibyte Subtraction Routine 6"^ 

Multiplication in Expressions ......,,..,,.,..,,.,,..,,. = ,.2-12 

Multiply (Software Example) . , . . , : ...,,, , .,.,..., = ,,,..- > > 6-7 

MVi (Move Immediate) ,,.,,..,,,...,.,.,.,,.,...,,.,.. 3-37 

NAME Directive ...,...,.,.,.,..,,....,..,......-.. 4-18 

NE Operator .....,,,,..,,,, ,,,..,.,,.,,,,.. 2-13 

Nested Macro Calls .,,.,,, = . ; ..,,.....,.,,,..*,,,... 5-14 

Nested Maco Definitions 5-12 

Nested Subroutines ,.,,,..,.,,,.....,,.,,.. = ,.....,, 3-48 

Nine's Comotement ,,,,,,,.,,,..,.,,...,,,., = = .. = ,,, 2-7 

NOP (No Operation) Instruction ......,,,,.,..... , 3-38 



1-4 



NOP via MOV . , . , ...................... \ ... . 3-36 

NOT Operator .....,...,.....,.,.. 2-73 

NUL Operator . , ,..,..........,...,.,,..... 2-13, 5-77 

Null Macros ......... 5-1 6 

Null Parameter .............. . . . - - - - 5-11 

Object Code .,..,.......,.,.,,.. , 1-2 

Object File ..,......,.,..,.,,......,......,,,.. 1-1 

Octal Data (Coding Rules) .........,.....,,,.,. . 2-5 

One's Complement ................. ........... 2-7 

Opcode ..,................,,......,..,.,.,.,. 1-1 

Opcode Field ............................... 2-4 

Operand Field .................... ,,,..,.,... 2 " 4 

Operand Field (Coding Rules) ............................ 2-4 

Operands ,.......,,,,..,,...,......,....,...... 2-5 

Operators, Expression ......................... 2-11 

OR Operator ...,...,..,.,.....,,,.....,.,...,,., 2 ~ 13 

ORG (Origin) Directive (Absolute Mode) , , ...... . . . , . . . , , . . . . . . 4 ' 11 

ORG (Origin) Directive (Relocatable Mode) ...... 4 ^ 6 

ORA (Inclusive OR) Instruction ........................... 3-38 

OR! (Inclusive OR immediate) ..................... . 3 ' 40 

OUT Instruction ............................... . 1-14, 5-47 

PAGE Reserved Word .,........,.....,..,.....,.,. .4,-7^ 4-75 

Parity Flag /-// 

PCHL (Move H & L to Program Counter) Instruction ,,..,.., 3-42 

Permanent Symbols 2-1 1 

PL/M .........,,...,.....,.....,.....,.,.,. 1-3 

PL/M Compared with Assembler ,.,....,.,....,.,.......,.. 1-3 

POP Instruction 3-42 

POP PSW instruction . , , ..,,.,....,.-.......,,. 3-43 

Precedence of Expression Operators ...,....,,,,...., , 2-75 

Processor Registers ..,,,,....,,,...., 1-9 

Program Counter .................................. 1-6 

Program Linkage Directives ............................. 4-76 

Program Listing .,,.........,.......,..,..,...,,.., 1-2 

Program Status ...,,,..,..,..,..,....,..,......... 1-13 

Program Status Word (PSW) ............................. 7-74 

Programming the 8085 ..,,,......,.,.....,.....,,...., 1-24 

PROM ......................... 1-5 

PSW 7-74, 345 

PUBLIC Directive .,.....,....,....,,.........,..,,. 4-77 

PUSH Instruction .,.....,....,.,.. 3 ~ 44 

PUSH PSW Instruction ,.,..........,....,. 3 ^ 5 

RAM 1-5 

RAM versus ROM 4-6 

RAL (Rotate Left through Carry) Instruction .,.,.....,,.,,.. 3-45 



1-5 



RAR (Rotite Right through Carry} Instruction ....,.......-...-..> 3-46 

RC (Return if Carry) instruction ,,.,,..,,...,,.,........... 3-47 

RedefinabSe Symbols .,,,,.. . .............. . . - > . ...... 2-1 1 

Register Addressing ..,.,.,.,,. ..,,.,...,.... 7-75 

Register Indirect Addressing ......,..,,,. .,.,.,,.,,.. 7-76 

Register Pair Instructions ...,.,,.,,,...,,.. 7-27 

Register Pairs ,,..,.,.,.,..,,,..,,.,,........ 1-7 

ReSocatabiiity Defined ,,.,,,.,,.,.............= < > . * • . . 4-72 

Relocatable Expressions .2-76, 2-79 

Relocatable Symbols ,.,..,....... .,......,,,,,..,2-11 

Relocation Feature .,.,,..,...,,..,.. ,,.,....,. 1-2 

Reserved Symbols ,....,..,.,,,.,.,,.,..,..•>..>..•> 2-9 

RESET Signal ......,,.,......,♦.,....... . . - , - . - . ^ 3-24 

RET (Return) Instruction , . . . . ..,,,,.,,...,,.,,... 3-48 

REPT Directive ,..,..,,, \ ........... . 5-6,5-12,5-15,5-16,5-17,5-18 

RIM (Read Interrupt Mask) 8085 Instruction .....,,,...,.,,....>. 3-48 

RLC (Route Accumulator Left) Instruction ,..,.,.,..,.,.., 3-49 

RM (Retui n if Minus) Instruction ,..,,.,.,.,,,...,.,.>..,.. 3-50 

RNC (Return if no Carry) Instruction .,,.,.,,....,.... = , , . . < - 3-51 

RNZ (Return if not Zero) Instruction .,.,.,......,.,.......,. 3-57 

ROM ..,...,,,.....,..,........ - .... , . . = . . . 1-5 

RP (Retur i if Positive) Instruction .,,,.,,.,.,,,.,,,,..,.,... 3-52 

RPE (Rettrn if Parity Even) Instruction ,,...,..,....,, 3-52 

RPO (Return if Parity Odd) Instruction ..,.........,...,,.. = .- 3-53 

RRC (Route Accumulator Right) Instruction ,.,,,.,....,.= 3-53 

RST (Restirt) Instruction ,.,.,..,..,,,,...,,,.. ........ 3-54 

RST5.5 , .,,..,..,.,.,...,..... 3-49, 3-55, 3-59, 3-60 

RST6.5 .............. 3-49, 3-55, 3-59, 3-60 

RST7.5 ...,,,...,.,,....,............* 3-49, 3-55, 3-59, 3-60 

RZ (Return if Zero) Instruction .,....,....-.,,,.,...-.. = = . 3-55 

Savings Program Status .,,.....,..,,..,....,. = ......'> 7-73 

S8B (Subtract with Borrow) Instruction ........ 3-56 

SBI (Subtiact Immediate with Borrow) Instruction ,..,...,.,., = ,..-. 3-57 

Scope of Symbols ..> T .,,,,. \ ....,..,... = ... = >..*.= 2-10 

SET Direc:ive ..,.,..,.,.,,....,,..,.-....-.-• 4-3 

Shift Expression Operators . . . ........................ . . 2-12 

Shift Operations in Expressions ......,.,...,,.....,.>,,... 2-1 2 

SHL Oper.itor ........... 2-12 

SHLD (Store H & L Direct) Instruction .,..,.,...,.......,. = > 3-58 

SHR Operator ,...,.....,,.........,,.... , . . , . . . . 2-12 

Sign Flag .......................... 7-70 

SIM (Set Interrupt Mask) 8085 Instruction .,,,,,..,...,.,.,..., 3-59 

Software Divide Routine ...,,.,...,....,.. 6-7 

Software I Multiply Routine .,,...,..,,,.,.,...-.,....,... 6-7 

Source Code Format ,..,,....,.............> = .... = .. 2-1 

Source Line Fields ....,,,.....,..,.....-..-.. . • ... * 2-1 

Source Program File ..................... 1-1 

SPHL (Mcve H & L to Stack Pointer) Instruction ................. 3-67 



1-6 



SP (Stack Pointer Register) ..,.,.,.,...,,,,,...,,,...,,.. 3 " 35 

5TA (Store Accumulator Direct) Instruction ,.,.,,,,,,,.,.,..,..,. 3-61 

Stack ....,.,, ,...,,... 7 " 72 

Stack and Machine Control Instructions .,....,,.,,,,.,,.....,., '"'^ 

Stack Operations ...,...,,......,,.......,,,..,..,., ^ 3 

Stack Pointer , .,.,.,,... ,,.........,... J ' 12 

STACK Reserved Word ....,.......,....,,,,,,...,... ^-75, 3-35 

Start Execution Address ..,.,..,.,,,..,,,....,.....,,,. 4-10 

STAX (Store Accumulator Indirect) instruction .,.....,.,,..,.,.,... 3-62 

STC (Set Carry) Instruction ,,,.,,.,.,..,,...,. .,..,, 3 ' 63 

STKLN Directive . . . . ...,....,,,..,.,.,,... 4 " /5 

SUB (Subtract) Instruction ,,,,,..,,...,,........., 3-63 

Subroutine Data ......,..,...,..,,,,,.,,,,,,...,.,, °" 3 

Subroutines >,,,,.,,,,.,.,.,.,,. , .,..,.,,,,.,,,, 7 : 72, ^ 

Subroutines versus Macros ,,..,,,..,.,,.,.,,,..,.......,. ^-3 

Subtraction for Comparison ..,,........,..,......,....,,. ^-12 

SUI (Subtract Immediate) Instruction .,,.;,,.,,,.:,,,.,,...,.,, 3-64 

Symbol-Cross-Reference File ,,......,........, ,.,)''* '~3 

Symbol Definition ,.,......,,...,...,.,.,,,..,..,.,,, ^ 

Symbol Table . . , ,,,,....,....,..,,..,.,.... 2-9 

Symbolic Addressing ..,.,..,,,.,.,,,.,.,,,.......,.,. 2-9 

Symbols .,...,..,.,..,,.:..,,......,- , , , . . -~* 

Symbols, Absolute ,,.,...,.........,...,,.,.....,.., 2-11 

Symbols (Coding Rules) ..,.,......,.,...,., : , . . , . 2-9 

Symbols, Global ...,...,.,.,.,,,,.,,. , . 2-10 

Symbols, Limited .,,..,.......,.,.,.....,...,,..,.,. 2-10 

Symbols, Permanent .,,...,.,,..,.,.,.,.,,..,,,.....,. 2-11 

Symbols, Redefinabie ..,,...,,...,.,,,..., ,..>>,.. 2-11 

Symbols, Relocatable ,,:,...,.,....,.,..,., , . . . 2-11 

Symbols, Reserved ..,,..,.,.,,.., .,,, : ..... , 2-9 

TRAP Interrupt ,,.......,,,...,..,,.,......,..,.,,. 3-54 

Ten's Complement ..,,.:.,...,,.......,....,.,.,.... 2-7 

Testing Relocatable Modules .,.,,.,,,,,.:.,.,,., . . 4-19 

Timing Effects of Addressing Modes .,..,,........,... 1-16 

TRAP (8085) .....,,.,.,,.....,.........,. 3-23 

Two's Complement Data .,..,,.,,,:..,...,....., , 2-7 

Use of Macros ,..,,,>,,.,,.>,.,,...-.....,.....,,. 5-1 

Using Symbols for Data Access ..,,..,,,,....,.,...,.,.,,:. 4-7 

Value of Expressions , , , ..,...,.....,.,.,,,.,.> 2-15 

What is a Macro? ...,.....,....,....,.,,...,,,,,.... 5-2 

Word Instructions ......,,.,,,.....,,.,... = ,,.,.,..,. 7-27 

Word Storage in Memory ,..,...,,....,,.,,,,....,...,.. 4-4 

Work Registers .................................... 1-7 



1-7 



XCHG (Excttange H & L with D & E) Instruction .,....,,,,, , . 3-65 

XOR Operator ,,.,,,..,,.,..,.,,..,..,.,,..,.,.,,. 2-13 

XRA (Exciu>ive OR) Instruction ,,,..,,..,..,..,....,....,. 3-66 

XRl (Exclus ve OR immediate) Instruction ,....,..,,,,..,,..,.,.. 3-67 

XTHL (Exchange H & L with Top of Stack) Instruction ,...,,.>,..,,,, 3-69 

Zero Flag 7-7 7 

&. (amper:and) . T = ,..,.,,,..,......,.,.,.,,.,..,.. 5-10 

<> (angle brackets) ,,,...,,.,.,,.. ; ..,,,,,... : .,,,,. 5-10 

CR (carriage return character) ...,......,.,.,.......,...,. 2-2 

; (colon) ,..,,. ,......,,.,,,,.......,. 2-2 

(comm.L) ,,...,.,,,:,.,,.,, = ..,,,....,.,.,:,. 2-2 

;; (double semicolon) ,,,,... : ..,,, t ,.,,,,... : ; . = ,,,. 5-1 

/ (divisio i) Operator . 2-12 

! (exclarration point) ....,..,,:,,.,,,..::,,.,:,,.,., 5-10 

HT (horizoital tab character) ..:,.,,,.: = ....,,.,.,..,,.,, 2-2 

— (minus) Operator . . 

* (muitipiicatton) Operator . , . 2-12 

( ) (parent leses) ...,..,,.,..,,...,.,,,,.,.,:..,.,. 2-2 

+ (plus) Operator .,,.,, . 2-12 

??nnnn Symbo-s ..-,-,,,, , ,....,>,...., 5-5 

; (semicc Ion) .:..,....>.,.:...,,.,,,,,:-.,: 2-2 

(single quote) ..,..,..,...,..,.,,.,,,..,,-:..,: 2-2 

space (character) .....,.,...,,,.,,:.....,,,,..,.,,,, 2-2 

8080/8085 Differences ...,,,...........,..,., . . 1-24 

8085 Features , .,...,,......,,.,., 1-24 

8085 Processor ,...,....., ......,,..,,,,,..,= 1-24 

8085 Programming 1-24 



1-8 



NOTES 



NOTES 



